{"id":10025,"date":"2025-10-24T18:22:18","date_gmt":"2025-10-24T09:22:18","guid":{"rendered":"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/?p=10025"},"modified":"2025-11-16T07:28:30","modified_gmt":"2025-11-15T22:28:30","slug":"spring-security%e5%b0%8f%e3%83%8d%e3%82%bf","status":"publish","type":"post","link":"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/archives\/10025","title":{"rendered":"spring security\u5c0f\u30cd\u30bf"},"content":{"rendered":"<div class=\"veu_autoEyeCatchBox\"><img loading=\"lazy\" decoding=\"async\" width=\"750\" height=\"649\" src=\"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-content\/uploads\/2025\/10\/\u864e\u5fb9\u3068\u83ca.jpg\" class=\"attachment-large size-large wp-post-image\" alt=\"\u732b\u597d\u304d\u30ea\u30fc\u30de\u30f3\" srcset=\"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-content\/uploads\/2025\/10\/\u864e\u5fb9\u3068\u83ca.jpg 800w, https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-content\/uploads\/2025\/10\/\u864e\u5fb9\u3068\u83ca-300x260.jpg 300w, https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-content\/uploads\/2025\/10\/\u864e\u5fb9\u3068\u83ca-768x664.jpg 768w\" sizes=\"auto, (max-width: 750px) 100vw, 750px\" \/><\/div>\n<p>\u3053\u3093\u306b\u3061\u308f\u3001\u732b\u597d\u304d\u30ea\u30fc\u30de\u30f3\u306e\u307b\u3052PG\u3067\u3059\u3002<\/p>\n\n\n\n<p>3\u3064\u307b\u3069\u5c0f\u30cd\u30bf\u7d39\u4ecb\u3067\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">\uff11\uff0c&nbsp; \u30ed\u30b0\u30a4\u30f3\u30e6\u30fc\u30b6\u3092\u30ed\u30b0\u51fa\u529b\u3059\u308b<\/h3>\n\n\n\n<p>\u4ed5\u7d44\u307f\uff1a\u30bb\u30c3\u30b7\u30e7\u30f3\u306b\u8a8d\u8a3c\u60c5\u5831\u304c\u4fdd\u5b58\u3055\u308c\u3066\u3044\u308b\u306e\u3067\u3001\u30ea\u30af\u30a8\u30b9\u30c8\u306e\u5165\u308a\u53e3\u3067\u8a8d\u8a3c\u60c5\u5831\u3092\u53d6\u5f97\u3057MDC.put()\u3059\u308b\u3060\u3051\u3002<\/p>\n\n\n\n<p>\u30d5\u30a3\u30eb\u30bf\u30fc<\/p>\n\n\n\n<pre class=\"wp-block-code has-background\" style=\"background-color:#f6f6f6\"><code>@Component\n@Slf4j\npublic class HogeLoggingFilter extends CommonsRequestLoggingFilter {\n\n    @Override\n    protected boolean shouldLog(HttpServletRequest request) {\n        String uri = request.getServletPath();\n        return !checkStaticPath(uri);\n    }\n\n    private boolean checkStaticPath(String path) {\n        return path.startsWith(\"\/static\/\");\n    }\n\n    @Override\n    protected void beforeRequest(HttpServletRequest request, String message) {\n        LoginUser user = getLoginUser(request.getSession(false));\n        if (user != null) {\n            MDC.put(\"USER-ID\", user.getId());\n        }\n    }\n\n    public LoginUser getLoginUser(HttpSession session) {\n        if (session != null) {\n            SecurityContext securityContext = (SecurityContext) session.getAttribute(\"SPRING_SECURITY_CONTEXT\");\n            if (securityContext != null) {\n                Authentication authentication = securityContext.getAuthentication();\n                return (LoginUser) authentication.getPrincipal();\n            }\n        }\n        return null;\n    }\n\n    @Override\n    protected void afterRequest(HttpServletRequest request, String message) {\n        MDC.remove(\"USER-ID\");\n    }\n}<\/code><\/pre>\n\n\n\n<p>\u203b\u7d99\u627f\u5143\u304c\u7528\u9014\u306b\u5408\u3063\u3066\u3044\u306a\u3044\u306e\u3067javax.servlet.Filter \u3092\u4f7f\u3063\u305f\u65b9\u304c\u826f\u3044\u304b\u3082<\/p>\n\n\n\n<p>\u30ed\u30b0\u5b9a\u7fa9<\/p>\n\n\n\n<pre class=\"wp-block-code has-background\" style=\"background-color:#f3f1f1\"><code>    &lt;appender name=\"STDOUT\" class=\"ch.qos.logback.core.ConsoleAppender\"&gt;\n        &lt;target&gt;System.out&lt;\/target&gt;\n        &lt;encoder&gt;\n            &lt;charset&gt;UTF-8&lt;\/charset&gt;\n            &lt;pattern&gt;%date{yyyy-MM-dd HH:mm:ss} %-5level %5.5thread %X{USER-ID} \\(%file:%line\\) %M - %msg%n&lt;\/pattern&gt;\n        &lt;\/encoder&gt;\n    &lt;\/appender&gt;<\/code><\/pre>\n\n\n\n<p><\/p>\n\n\n\n<div style=\"height:50px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">\uff12\uff0c&nbsp; \u66f4\u65b0\u7cfbSQL\u3060\u3051\u30ed\u30b0\u51fa\u529b\u3059\u308b<\/h3>\n\n\n\n<p>\u4ed5\u7d44\u307f\uff1amybatis\u9650\u5b9a\u306b\u306a\u308b\u304c\u3001Mapper\u306e\u30e1\u30bd\u30c3\u30c9\u540d\u3092\u66f4\u65b0\u7cfb\u306finsert\/update\/delete\u3067\u59cb\u307e\u308b\u30e1\u30bd\u30c3\u30c9\u540d\u306b\u3057\u3001\u30ed\u30b0\u30d5\u30a3\u30eb\u30bf\u30fc\u3067\u30ed\u30ac\u30fc\u540d\u304b\u3089\u66f4\u65b0\u7cfb\u304b\u5224\u65ad\u3059\u308b\u3002<\/p>\n\n\n\n<p>\u30ed\u30b0\u30d5\u30a3\u30eb\u30bf\u30fc<\/p>\n\n\n\n<pre class=\"wp-block-code has-background\" style=\"background-color:#eeeeee\"><code>public class SqlLogFilter extends Filter&lt;ILoggingEvent> {\n    private static final List&lt;String> DEFAULT_ACCEPT = List.of(\"insert\", \"update\", \"delete\");\n\n    private static boolean checkName(String name) {\n        for (String s : DEFAULT_ACCEPT) {\n            if (name.startsWith(s)) {\n                return true;\n            }\n        }\n        return false;\n    }\n\n    @Override\n    public FilterReply decide(ILoggingEvent event) {\n        String loggerName = event.getLoggerName();\n        if (loggerName.startsWith(\"jp.co.ois.hoge.springsecurity.mapper\")) {\n            int ix = loggerName.lastIndexOf(\".\");\n            String name = loggerName.substring(ix + 1);\n            if (!checkName(name)) {\n                return FilterReply.DENY;\n            }\n        }\n        return FilterReply.ACCEPT;\n    }\n}<\/code><\/pre>\n\n\n\n<p>\u30ed\u30b0\u5b9a\u7fa9<\/p>\n\n\n\n<pre class=\"wp-block-code has-background\" style=\"background-color:#f3f2f2\"><code>    &lt;appender name=\"STDOUT\" class=\"ch.qos.logback.core.ConsoleAppender\"&gt;\n        &lt;target&gt;System.out&lt;\/target&gt;\n        \u2026\n        &lt;filter class=\"jp.co.ois.hoge.springsecurity.util.SqlLogFilter\" \/&gt;\n    &lt;\/appender&gt;<\/code><\/pre>\n\n\n\n<div style=\"height:50px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">\uff13\uff0c&nbsp; \u8d77\u52d5\u6642\u306bwar\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u3092\u30ed\u30b0\u51fa\u529b\u3059\u308b<\/h3>\n\n\n\n<p>\u4ed5\u7d44\u307f\uff1a\u8d77\u52d5\u7d42\u4e86\u30ea\u30b9\u30ca\u30fc\u3067ServletContextEvent\u304b\u3089MANIFEST.MF\u3092\u53c2\u7167\u3057\u3001\u30ed\u30b0\u51fa\u529b\u3059\u308b\u3002<\/p>\n\n\n\n<p>\u8d77\u52d5\u7d42\u4e86\u30ea\u30b9\u30ca\u30fc<\/p>\n\n\n\n<pre class=\"wp-block-code has-background\" style=\"background-color:#f1f1f1\"><code>@WebListener\n@Slf4j\npublic class HogeContextListener implements ServletContextListener {\n\n    @Override\n    public void contextInitialized(ServletContextEvent sce) {\n        log.info(\"Starting.\");\n        ServletContext sc = sce.getServletContext();\n        String metafile = \"\/META-INF\/MANIFEST.MF\";\n        try (InputStream is = sc.getResourceAsStream(metafile)) {\n            byte&#091;] bytes = is.readAllBytes();\n            String meta = new String(bytes, StandardCharsets.UTF_8);\n            meta.lines()\n                .filter(s -&gt; s.startsWith(\"Implementation-Version\"))\n                .forEach(this::info);\n        } catch (IOException e) {\n            log.error(e.toString(), e);\n        }\n    }\n    \n    private void info(String s) {\n        log.info(s);\n    }\n    \n    @Override\n    public void contextDestroyed(ServletContextEvent sce) {\n        log.info(\"Shutdown.\");\n    }\n}<\/code><\/pre>\n\n\n\n<p><\/p>\n\n\n\n<p>\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u4e00\u5f0f\u3092\u6dfb\u4ed8\u3057\u3066\u304a\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/ois-yokohama.co.jp\/oisblog2018\/file\/hoge-springsecurity.zip\"><img loading=\"lazy\" decoding=\"async\" width=\"156\" height=\"55\" src=\"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-content\/uploads\/2025\/10\/image.png\" alt=\"\" class=\"wp-image-10030\"\/><\/a><\/figure>\n","protected":false},"excerpt":{"rendered":"<p>\u3053\u3093\u306b\u3061\u308f\u3001\u732b\u597d\u304d\u30ea\u30fc\u30de\u30f3\u306e\u307b\u3052PG\u3067\u3059\u3002 3\u3064\u307b\u3069\u5c0f\u30cd\u30bf\u7d39\u4ecb\u3067\u3059\u3002 \uff11\uff0c&nbsp; \u30ed\u30b0\u30a4\u30f3\u30e6\u30fc\u30b6\u3092\u30ed\u30b0\u51fa\u529b\u3059\u308b \u4ed5\u7d44\u307f\uff1a\u30bb\u30c3\u30b7\u30e7\u30f3\u306b\u8a8d\u8a3c\u60c5\u5831\u304c\u4fdd\u5b58\u3055\u308c\u3066\u3044\u308b\u306e\u3067\u3001\u30ea\u30af\u30a8\u30b9\u30c8\u306e\u5165\u308a\u53e3\u3067\u8a8d\u8a3c\u60c5\u5831\u3092\u53d6\u5f97\u3057MDC.put( [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":10033,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"om_disable_all_campaigns":false,"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"vkexunit_cta_each_option":"","footnotes":""},"categories":[6],"tags":[28,1167,1166,1165,1171,1172,1178],"class_list":["post-10025","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-engineer","tag-hoge","tag-logback","tag-spring-security-5","tag-springboot-2-7","tag-1171","tag-sql","tag-war"],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-json\/wp\/v2\/posts\/10025","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-json\/wp\/v2\/comments?post=10025"}],"version-history":[{"count":8,"href":"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-json\/wp\/v2\/posts\/10025\/revisions"}],"predecessor-version":[{"id":10037,"href":"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-json\/wp\/v2\/posts\/10025\/revisions\/10037"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-json\/wp\/v2\/media\/10033"}],"wp:attachment":[{"href":"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-json\/wp\/v2\/media?parent=10025"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-json\/wp\/v2\/categories?post=10025"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.ois-yokohama.co.jp\/oisblog2018\/wp-json\/wp\/v2\/tags?post=10025"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}