{"id":11151,"date":"2026-02-24T16:30:34","date_gmt":"2026-02-24T07:30:34","guid":{"rendered":"https:\/\/code-plus.jp\/gp\/?p=11151"},"modified":"2026-02-25T19:22:05","modified_gmt":"2026-02-25T10:22:05","slug":"wordpress-htaccess-11151","status":"publish","type":"post","link":"https:\/\/code-plus.jp\/gp\/wordpress-htaccess-11151\/","title":{"rendered":"WordPress\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u306e\u7b2c\u4e00\u6b69\uff5c.htaccess\u3067\u4eca\u3059\u3050\u3067\u304d\u308b7\u3064\u306e\u5bfe\u7b56"},"content":{"rendered":"<p>WordPress\u30b5\u30a4\u30c8\u304c\u7a81\u7136\u3001\u77e5\u3089\u306a\u3044\u30b7\u30e7\u30c3\u30d4\u30f3\u30b0\u30b5\u30a4\u30c8\u306b\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u3055\u308c\u308b\u2014\u2014\u3002<\/p>\r\n<p>\u3053\u308c\u306f\u300cSEO\u30b9\u30d1\u30e0\u653b\u6483\u300d\u3068\u547c\u3070\u308c\u308b\u5178\u578b\u7684\u306a\u30cf\u30c3\u30ad\u30f3\u30b0\u624b\u53e3\u306e\u3072\u3068\u3064\u3067\u3059\u3002Google\u304b\u3089\u306e\u30a2\u30af\u30bb\u30b9\u3060\u3051\u5225\u30b5\u30a4\u30c8\u306b\u8a98\u5c0e\u3057\u3001\u30b5\u30a4\u30c8\u7ba1\u7406\u8005\u304c\u76f4\u63a5URL\u3092\u5165\u529b\u3059\u308b\u3068\u6b63\u5e38\u306b\u898b\u3048\u308b\u305f\u3081\u3001\u88ab\u5bb3\u306b\u6c17\u3065\u304f\u306e\u304c\u9045\u308c\u3084\u3059\u3044\u653b\u6483\u3067\u3059\u3002<\/p>\r\n<p>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u306b\u306f\u3055\u307e\u3056\u307e\u306a\u65b9\u6cd5\u304c\u3042\u308a\u307e\u3059\u304c\u3001<b class=\"bold\">\u307e\u305a\u6700\u521d\u306b\u624b\u3092\u3064\u3051\u308b\u3079\u304d\u306a\u306e\u304c\u30b5\u30fc\u30d0\u30fc\u306e\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb <code>.htaccess<\/code> \u3067\u3059<\/b>\u3002\u30d7\u30e9\u30b0\u30a4\u30f3\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u4e0d\u8981\u3067\u3001\u30b3\u30fc\u30c9\u3092\u8cbc\u308a\u4ed8\u3051\u308b\u3060\u3051\u3067\u52b9\u679c\u304c\u51fa\u307e\u3059\u3002<\/p>\r\n<p>\u3053\u306e\u8a18\u4e8b\u3067\u306f\u3001\u30b3\u30d4\u30da\u3067\u4f7f\u3048\u308b <code>.htaccess<\/code> \u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u8a2d\u5b9a\u30927\u3064\u7d39\u4ecb\u3057\u307e\u3059\u3002<\/p>\r\n\r\n<!-- \u2605\u76ee\u6b21\u30ea\u30b9\u30c8 -->\r\n<ul class=\"tocList mt-1r\" data-toc-id=\"js-tocBWGD\"><\/ul>\r\n<ins class=\"tocBtn is-fixed\" data-toc-id=\"js-tocBWGD\"><\/ins>\r\n<!-- \u76ee\u6b21\uff1aJS -->\r\n<script src=\"https:\/\/code-plus.jp\/cdn\/js\/_gimmicks\/inppend-tocList.js\"><\/script>\r\n<script src=\"https:\/\/code-plus.jp\/cdn\/js\/_gimmicks\/inppend-tocBtn.js\"><\/script>\r\n\r\n\r\n\r\n\r\n<h2 class=\"fz-xl\">.htaccess \u3068\u306f\uff1f<\/h2>\r\n<p><code>.htaccess<\/code>\uff08\u30cf\u30c3\u30c8\u30a2\u30af\u30bb\u30b9\uff09\u306f\u3001Apache\u30b5\u30fc\u30d0\u30fc\u306b\u7f6e\u304f\u3053\u3068\u3067<b class=\"bold\">\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u5358\u4f4d\u3067\u30b5\u30fc\u30d0\u30fc\u306e\u6319\u52d5\u3092\u5236\u5fa1\u3067\u304d\u308b\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb<\/b>\u3067\u3059\u3002WordPress\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b\u3068\u3001\u30eb\u30fc\u30c8\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306b\u81ea\u52d5\u751f\u6210\u3055\u308c\u307e\u3059\u3002<\/p>\r\n<p>\u3053\u306e1\u30d5\u30a1\u30a4\u30eb\u3067\u3001\u30a2\u30af\u30bb\u30b9\u5236\u9650\u30fb\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u30fb\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30d8\u30c3\u30c0\u30fc\u306e\u8a2d\u5b9a\u306a\u3069\u3001\u591a\u304f\u306e\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002\u9006\u306b\u8a00\u3048\u3070\u3001<b class=\"bold\">\u3053\u3053\u3092\u6539\u3056\u3093\u3055\u308c\u308b\u3068\u653b\u6483\u8005\u306b\u601d\u3044\u901a\u308a\u306e\u5236\u5fa1\u3092\u4e0e\u3048\u3066\u3057\u307e\u3046<\/b>\u305f\u3081\u3001\u4fdd\u8b77\u304c\u91cd\u8981\u3067\u3059\u3002<\/p>\r\n<h2 class=\"fz-xl\">\u5bfe\u7b561\uff1a\u91cd\u8981\u30d5\u30a1\u30a4\u30eb\u3078\u306e\u30a2\u30af\u30bb\u30b9\u5236\u9650<\/h2>\r\n<p><code>wp-config.php<\/code> \u306f\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306e\u30d1\u30b9\u30ef\u30fc\u30c9\u306a\u3069\u3001\u30b5\u30a4\u30c8\u904b\u55b6\u306b\u5fc5\u8981\u306a\u6a5f\u5bc6\u60c5\u5831\u304c\u542b\u307e\u308c\u305f\u6700\u91cd\u8981\u30d5\u30a1\u30a4\u30eb\u3067\u3059\u3002\u5916\u90e8\u304b\u3089\u76f4\u63a5\u30a2\u30af\u30bb\u30b9\u3067\u304d\u306a\u3044\u3088\u3046\u5236\u9650\u3057\u307e\u3059\u3002<\/p>\r\n<pre><code class=\"language-apache\"># WordPress\u91cd\u8981\u30d5\u30a1\u30a4\u30eb\u3078\u306e\u30a2\u30af\u30bb\u30b9\u5236\u9650\r\n&lt;FilesMatch &quot;^(wp-config\\.php|.*\\.(hta)|wp-mail\\.php|install\\.php|xmlrpc\\.php)___PRE_BLOCK_0___quot;&gt;\r\n  Order Allow,Deny\r\n  Deny from all\r\n  Require all denied\r\n&lt;\/FilesMatch&gt;\r\n\r\n# WordPress\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u60c5\u5831\u6f0f\u6d29\u9632\u6b62\r\n&lt;FilesMatch &quot;^(readme\\.html|license\\.txt)___PRE_BLOCK_0___quot;&gt;\r\n  Order Allow,Deny\r\n  Deny from all\r\n  Require all denied\r\n&lt;\/FilesMatch&gt;\r\n<\/code><\/pre>\r\n<p><code>readme.html<\/code> \u3084 <code>license.txt<\/code> \u306fWordPress\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u304c\u8a18\u8f09\u3055\u308c\u3066\u3044\u308b\u305f\u3081\u3001\u653b\u6483\u8005\u306b\u8106\u5f31\u6027\u306e\u7279\u5b9a\u3092\u8a31\u3059\u60c5\u5831\u6e90\u306b\u306a\u308a\u307e\u3059\u3002\u3042\u308f\u305b\u3066\u975e\u516c\u958b\u306b\u3057\u3066\u304a\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\r\n<h2 class=\"fz-xl\">\u5bfe\u7b562\uff1a\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u30ea\u30b9\u30c6\u30a3\u30f3\u30b0\u306e\u9632\u6b62<\/h2>\r\n<p><code>Options -Indexes<\/code> \u306e1\u884c\u3092\u8ffd\u52a0\u3059\u308b\u3060\u3051\u3067\u3001\u30d5\u30a1\u30a4\u30eb\u304c\u4e00\u89a7\u8868\u793a\u3055\u308c\u308b\u306e\u3092\u9632\u3052\u307e\u3059\u3002<\/p>\r\n<pre><code class=\"language-apache\"># \u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u30ea\u30b9\u30c6\u30a3\u30f3\u30b0\u9632\u6b62\r\nOptions -Indexes\r\n<\/code><\/pre>\r\n<p>\u3053\u306e\u8a2d\u5b9a\u304c\u306a\u3044\u72b6\u614b\u3067 <code>https:\/\/example.com\/wp-content\/uploads\/<\/code> \u306b\u30a2\u30af\u30bb\u30b9\u3059\u308b\u3068\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u305f\u30d5\u30a1\u30a4\u30eb\u304c\u4e00\u89a7\u8868\u793a\u3055\u308c\u3066\u3057\u307e\u3046\u3053\u3068\u304c\u3042\u308a\u307e\u3059\u3002\u500b\u4eba\u60c5\u5831\u3092\u542b\u3080\u30d5\u30a1\u30a4\u30eb\u304c\u3042\u308b\u5834\u5408\u306f\u7279\u306b\u91cd\u8981\u306a\u8a2d\u5b9a\u3067\u3059\u3002<\/p>\r\n<h2 class=\"fz-xl\">\u5bfe\u7b563\uff1awp-includes\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u5185\u306ePHP\u30d5\u30a1\u30a4\u30eb\u3092\u76f4\u63a5\u5b9f\u884c\u7981\u6b62<\/h2>\r\n<p><code>wp-includes<\/code> \u306fWordPress\u306e\u30b3\u30a2\u30d5\u30a1\u30a4\u30eb\u304c\u683c\u7d0d\u3055\u308c\u305f\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3067\u3059\u3002\u3053\u3053\u306b\u3042\u308bPHP\u30d5\u30a1\u30a4\u30eb\u306fWordPress\u304c\u5185\u90e8\u7684\u306b\u547c\u3073\u51fa\u3059\u3082\u306e\u3067\u3001\u5916\u90e8\u304b\u3089\u76f4\u63a5URL\u3067\u30a2\u30af\u30bb\u30b9\u3055\u308c\u308b\u5fc5\u8981\u306f\u3042\u308a\u307e\u305b\u3093\u3002<\/p>\r\n<pre><code class=\"language-apache\"># wp-includes\u5185\u306ePHP\u3092\u76f4\u63a5\u5b9f\u884c\u7981\u6b62\r\n&lt;IfModule mod_rewrite.c&gt;\r\n  RewriteEngine On\r\n  RewriteBase \/\r\n  RewriteRule ^wp-admin\/includes\/ - &lsqb;F,L&rsqb;\r\n  RewriteRule !^wp-includes\/ - &lsqb;S=3&rsqb;\r\n  RewriteRule ^wp-includes\/&lsqb;^\/&rsqb;+\\.php$ - &lsqb;F,L&rsqb;\r\n  RewriteRule ^wp-includes\/js\/tinymce\/langs\/.+\\.php - &lsqb;F,L&rsqb;\r\n  RewriteRule ^wp-includes\/theme-compat\/ - &lsqb;F,L&rsqb;\r\n&lt;\/IfModule&gt;\r\n<\/code><\/pre>\r\n<p>\u4eca\u56de\u5bfe\u5fdc\u3057\u305f\u5b9f\u969b\u306e\u611f\u67d3\u4e8b\u4f8b\u3067\u306f\u3001<code>wp-includes<\/code> \u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306b\u507d\u88c5\u3055\u308c\u305f\u30d0\u30c3\u30af\u30c9\u30a2\u304c\u4ed5\u8fbc\u307e\u308c\u3066\u3044\u307e\u3057\u305f\u3002\u30d0\u30c3\u30af\u30c9\u30a2\u306fCSS\u30fb\u753b\u50cf\u30d5\u30a1\u30a4\u30eb\u306b\u898b\u305b\u304b\u3051\u3066\u914d\u7f6e\u3055\u308c\u3066\u304a\u308a\u3001\u524a\u9664\u3057\u3066\u3082\u81ea\u52d5\u5fa9\u5143\u3055\u308c\u308b\u300c\u6c38\u7d9a\u5316\u300d\u306e\u4ed5\u7d44\u307f\u307e\u3067\u5099\u3048\u3066\u3044\u307e\u3057\u305f\u3002<\/p>\r\n<h2 class=\"fz-xl\">\u5bfe\u7b564\uff1a\u30d0\u30c3\u30af\u30a2\u30c3\u30d7\u30fb\u30ed\u30b0\u30d5\u30a1\u30a4\u30eb\u306e\u4fdd\u8b77<\/h2>\r\n<p><code>.bak<\/code> \u3084 <code>.sql<\/code>\u3001<code>.zip<\/code> \u306a\u3069\u306e\u62e1\u5f35\u5b50\u306e\u30d5\u30a1\u30a4\u30eb\u304c\u516c\u958b\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306b\u6b8b\u3063\u3066\u3044\u308b\u3068\u3001\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306e\u4e2d\u8eab\u3084\u30d5\u30a1\u30a4\u30eb\u4e00\u5f0f\u3092\u305d\u306e\u307e\u307e\u53d6\u5f97\u3055\u308c\u308b\u30ea\u30b9\u30af\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\r\n<pre><code class=\"language-apache\"># \u30d0\u30c3\u30af\u30a2\u30c3\u30d7\u30d5\u30a1\u30a4\u30eb\u3084\u30ed\u30b0\u30d5\u30a1\u30a4\u30eb\u306e\u4fdd\u8b77\r\n&lt;FilesMatch &quot;\\.(bak|log|sql|tar|gz|zip)___PRE_BLOCK_3___quot;&gt;\r\n  Order Allow,Deny\r\n  Deny from all\r\n  Require all denied\r\n&lt;\/FilesMatch&gt;\r\n<\/code><\/pre>\r\n<h2 class=\"fz-xl\">\u5bfe\u7b565\uff1a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30d8\u30c3\u30c0\u30fc\u306e\u8a2d\u5b9a<\/h2>\r\n<p>\u30d6\u30e9\u30a6\u30b6\u306b\u5bfe\u3057\u3066\u300c\u3053\u306e\u30b5\u30a4\u30c8\u306e\u5236\u7d04\u300d\u3092\u4f1d\u3048\u308b\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30d8\u30c3\u30c0\u30fc\u3092\u8a2d\u5b9a\u3057\u307e\u3059\u3002XSS\uff08\u30af\u30ed\u30b9\u30b5\u30a4\u30c8\u30b9\u30af\u30ea\u30d7\u30c6\u30a3\u30f3\u30b0\uff09\u3084\u30af\u30ea\u30c3\u30af\u30b8\u30e3\u30c3\u30ad\u30f3\u30b0\u306a\u3069\u306e\u653b\u6483\u3092\u9632\u3050\u52b9\u679c\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\r\n<pre><code class=\"language-apache\"># \u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30d8\u30c3\u30c0\u30fc\u8a2d\u5b9a\r\n&lt;IfModule mod_headers.c&gt;\r\n  # XSS Protection\r\n  Header set X-XSS-Protection &quot;1; mode=block&quot;\r\n  # MIME Type \u30b9\u30cb\u30c3\u30d5\u30a3\u30f3\u30b0\u9632\u6b62\uff08\u30d5\u30a1\u30a4\u30eb\u507d\u88c5\u5bfe\u7b56\uff09\r\n  Header set X-Content-Type-Options &quot;nosniff&quot;\r\n  # \u30af\u30ea\u30c3\u30af\u30b8\u30e3\u30c3\u30ad\u30f3\u30b0\u9632\u6b62\r\n  Header set X-Frame-Options &quot;SAMEORIGIN&quot;\r\n  # HTTPS\u5f37\u5236\uff08HSTS\uff09\r\n  Header always set Strict-Transport-Security &quot;max-age=31536000; includeSubDomains&quot;\r\n  # Referrer Policy\r\n  Header set Referrer-Policy &quot;strict-origin-when-cross-origin&quot;\r\n  # Feature Policy\r\n  Header set Permissions-Policy &quot;camera=(), microphone=(), geolocation=()&quot;\r\n&lt;\/IfModule&gt;\r\n<\/code><\/pre>\r\n<p><b class=\"bold\">\u5404\u30d8\u30c3\u30c0\u30fc\u306e\u5f79\u5272\uff1a<\/b><\/p>\r\n<table class=\"table tbl-responsive my-0.5r\">\r\n  <thead>\r\n  <tr class=\"rung\">\r\n    <th>\u30d8\u30c3\u30c0\u30fc<\/th>\r\n    <td>\u5f79\u5272<\/td>\r\n  <\/tr>\r\n<\/thead><tbody>\r\n<tr class=\"rung\">\r\n  <th>X-XSS-Protection<\/th>\r\n  <td>\u30d6\u30e9\u30a6\u30b6\u5074\u306eXSS\u30d5\u30a3\u30eb\u30bf\u30fc\u3092\u6709\u52b9\u5316<\/td>\r\n<\/tr><tr class=\"rung\">\r\n<th>X-Content-Type-Options<\/th>\r\n<td>\u30d5\u30a1\u30a4\u30eb\u306e\u7a2e\u985e\u3092\u507d\u88c5\u3057\u305f\u653b\u6483\u3092\u9632\u3050<\/td>\r\n<\/tr><tr class=\"rung\">\r\n<th>X-Frame-Options<\/th>\r\n<td>\u4ed6\u30b5\u30a4\u30c8\u306eiframe\u306b\u57cb\u3081\u8fbc\u307e\u308c\u308b\u3053\u3068\u3092\u9632\u3050<\/td>\r\n<\/tr><tr class=\"rung\">\r\n<th>Strict-Transport-Security<\/th>\r\n<td>HTTPS\u3078\u306e\u30a2\u30af\u30bb\u30b9\u3092\u5f37\u5236\u3059\u308b<\/td>\r\n<\/tr><tr class=\"rung\">\r\n<th>Referrer-Policy<\/th>\r\n<td>\u53c2\u7167\u5143\u60c5\u5831\u306e\u9001\u4fe1\u7bc4\u56f2\u3092\u5236\u9650\u3059\u308b<\/td>\r\n<\/tr>\r\n<\/tbody><\/table>\r\n<h2 class=\"fz-xl\">\u5bfe\u7b566\uff1aREST API\u3078\u306e\u30a2\u30af\u30bb\u30b9\u5236\u9650<\/h2>\r\n<p>WordPress REST API\u306f\u4fbf\u5229\u306a\u6a5f\u80fd\u3067\u3059\u304c\u3001\u672a\u8a8d\u8a3c\u306e\u307e\u307e\u3067\u306f\u6295\u7a3f\u30c7\u30fc\u30bf\u3084\u30e6\u30fc\u30b6\u30fc\u60c5\u5831\u304c\u5916\u90e8\u304b\u3089\u53d6\u5f97\u3067\u304d\u308b\u72b6\u614b\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002\u30ed\u30b0\u30a4\u30f3\u6e08\u307f\u30e6\u30fc\u30b6\u30fc\u4ee5\u5916\u306e\u30a2\u30af\u30bb\u30b9\u3092\u5236\u9650\u3057\u307e\u3059\u3002<\/p>\r\n<pre><code class=\"language-apache\"># REST API\u3078\u306e\u30a2\u30af\u30bb\u30b9\u5236\u9650\uff08\u8a8d\u8a3c\u6e08\u307f\u30e6\u30fc\u30b6\u30fc\u306e\u307f\u8a31\u53ef\uff09\r\n&lt;IfModule mod_rewrite.c&gt;\r\n  RewriteEngine On\r\n  RewriteCond %{REQUEST_URI} ^\/wp-json\/(.*)$ &lsqb;NC&rsqb;\r\n  RewriteCond %{HTTP_COOKIE} !wordpress_logged_in &lsqb;NC&rsqb;\r\n  RewriteRule ^(.*)$ - &lsqb;R=403,L&rsqb;\r\n&lt;\/IfModule&gt;\r\n<\/code><\/pre>\r\n<blockquote class=\"mt-0.75r\">\r\n<p><b class=\"bold\">\u6ce8\u610f\uff1a<\/b> REST API\u3092\u4f7f\u3046\u30d7\u30e9\u30b0\u30a4\u30f3\uff08\u30d5\u30a9\u30fc\u30e0\u30d7\u30e9\u30b0\u30a4\u30f3\u3001\u30e2\u30d0\u30a4\u30eb\u30a2\u30d7\u30ea\u9023\u643a\u306a\u3069\uff09\u3092\u4f7f\u7528\u3057\u3066\u3044\u308b\u5834\u5408\u306f\u3001\u52d5\u4f5c\u78ba\u8a8d\u3092\u884c\u3063\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\r\n<\/blockquote>\r\n<h2 class=\"fz-xl\">\u5bfe\u7b567\uff1aHTTPS\u5f37\u5236\u30ea\u30c0\u30a4\u30ec\u30af\u30c8<\/h2>\r\n<p>HTTP\u3067\u30a2\u30af\u30bb\u30b9\u3055\u308c\u305f\u5834\u5408\u3001\u81ea\u52d5\u7684\u306bHTTPS\u306b\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u3057\u307e\u3059\u3002SSL\u8a3c\u660e\u66f8\u3092\u5c0e\u5165\u3057\u3066\u3044\u308b\u5834\u5408\u306f\u5fc5\u9808\u306e\u8a2d\u5b9a\u3067\u3059\u3002<\/p>\r\n<pre><code class=\"language-apache\"># HTTPS\u5f37\u5236\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\r\nRewriteEngine on\r\nRewriteCond %{HTTPS} off\r\nRewriteRule ^(.*)$ https:\/\/%{HTTP_HOST}%{REQUEST_URI} &lsqb;R=301,L&rsqb;\r\n<\/code><\/pre>\r\n<h2 class=\"fz-xl\">\u6ce8\u610f\u70b9\uff1aFilesMatch\u3068Directory\u306e\u9055\u3044<\/h2>\r\n<p>\u3088\u304f\u3042\u308b\u9593\u9055\u3044\u3068\u3057\u3066\u3001<code>FilesMatch<\/code> \u3067\u30d1\u30b9\u3092\u6307\u5b9a\u3057\u3088\u3046\u3068\u3059\u308b\u30b1\u30fc\u30b9\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\r\n<pre><code class=\"language-apache\"># \u274c \u610f\u56f3\u3057\u305f\u52d5\u4f5c\u306b\u306a\u3089\u306a\u3044\r\n&lt;FilesMatch &quot;^wp-includes\/.*\\.json___PRE_BLOCK_7___quot;&gt;\r\n  Require all denied\r\n&lt;\/FilesMatch&gt;\r\n<\/code><\/pre>\r\n<p><code>FilesMatch<\/code> \u306f\u30d5\u30a1\u30a4\u30eb\u540d\u306b\u3057\u304b\u30de\u30c3\u30c1\u3057\u306a\u3044\u305f\u3081\u3001<code>wp-includes\/<\/code> \u306e\u90e8\u5206\u306f\u7121\u8996\u3055\u308c\u307e\u3059\u3002\u3053\u306e\u66f8\u304d\u65b9\u3067\u306f\u300c\u4e3b\u8981\u306aJSON\u30d5\u30a1\u30a4\u30eb\u300d\u304c\u5bfe\u8c61\u306b\u306a\u3063\u3066\u3057\u307e\u3044\u307e\u3059\u3002<\/p>\r\n<p>\u7279\u5b9a\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3092\u5bfe\u8c61\u306b\u3057\u305f\u3044\u5834\u5408\u306f <code>&lt;Directory&gt;<\/code> \u30d6\u30ed\u30c3\u30af\u3092\u4f7f\u3044\u307e\u3059\u3002\u305f\u3060\u3057\u3001<code>&lt;Directory&gt;<\/code> \u306f\u30b5\u30fc\u30d0\u30fc\u306e\u7d76\u5bfe\u30d1\u30b9\u3092\u8a18\u8ff0\u3059\u308b\u5fc5\u8981\u304c\u3042\u308b\u305f\u3081\u3001<code>.htaccess<\/code> \u3067\u306f\u4f7f\u3044\u306b\u304f\u3044\u5834\u9762\u3082\u3042\u308a\u307e\u3059\u3002<\/p>\r\n<h2 class=\"fz-xl\">\u307e\u3068\u3081\uff1a\u5b8c\u6210\u7248 .htaccess<\/h2>\r\n<p>\u4e0a\u8a18\u306e\u8a2d\u5b9a\u3092\u307e\u3068\u3081\u305f <code>.htaccess<\/code> \u306e\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u3067\u3059\uff08WordPress\u306e\u30eb\u30fc\u30c8\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306b\u8a2d\u7f6e\u3059\u308b\u30b1\u30fc\u30b9\u3092\u60f3\u5b9a\u3057\u3066\u3044\u307e\u3059\uff09\u3002<\/p>\r\n<pre><code class=\"language-apache\"># WordPress\u91cd\u8981\u30d5\u30a1\u30a4\u30eb\u3078\u306e\u30a2\u30af\u30bb\u30b9\u5236\u9650\r\n&lt;FilesMatch &quot;^(wp-config\\.php|.*\\.(hta)|wp-mail\\.php|install\\.php|xmlrpc\\.php)___PRE_BLOCK_8___quot;&gt;\r\n  Order Allow,Deny\r\n  Deny from all\r\n  Require all denied\r\n&lt;\/FilesMatch&gt;\r\n\r\n# WordPress\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u60c5\u5831\u6f0f\u6d29\u9632\u6b62\r\n&lt;FilesMatch &quot;^(readme\\.html|license\\.txt)___PRE_BLOCK_8___quot;&gt;\r\n  Order Allow,Deny\r\n  Deny from all\r\n  Require all denied\r\n&lt;\/FilesMatch&gt;\r\n\r\n# \u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u30ea\u30b9\u30c6\u30a3\u30f3\u30b0\u9632\u6b62\r\nOptions -Indexes\r\n\r\n# REST API\u3078\u306e\u30a2\u30af\u30bb\u30b9\u5236\u9650\uff08\u8a8d\u8a3c\u6e08\u307f\u30e6\u30fc\u30b6\u30fc\u306e\u307f\u8a31\u53ef\uff09\r\n&lt;IfModule mod_rewrite.c&gt;\r\n  RewriteEngine On\r\n  RewriteCond %{REQUEST_URI} ^\/wp-json\/(.*)$ &lsqb;NC&rsqb;\r\n  RewriteCond %{HTTP_COOKIE} !wordpress_logged_in &lsqb;NC&rsqb;\r\n  RewriteRule ^(.*)$ - &lsqb;R=403,L&rsqb;\r\n&lt;\/IfModule&gt;\r\n\r\n# \u30d0\u30c3\u30af\u30a2\u30c3\u30d7\u30d5\u30a1\u30a4\u30eb\u3084\u30ed\u30b0\u30d5\u30a1\u30a4\u30eb\u306e\u4fdd\u8b77\r\n&lt;FilesMatch &quot;\\.(bak|log|sql|tar|gz|zip)___PRE_BLOCK_8___quot;&gt;\r\n  Order Allow,Deny\r\n  Deny from all\r\n  Require all denied\r\n&lt;\/FilesMatch&gt;\r\n\r\n# \u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30d8\u30c3\u30c0\u30fc\u8a2d\u5b9a\r\n&lt;IfModule mod_headers.c&gt;\r\n  Header set X-XSS-Protection &quot;1; mode=block&quot;\r\n  Header set X-Content-Type-Options &quot;nosniff&quot;\r\n  Header set X-Frame-Options &quot;SAMEORIGIN&quot;\r\n  Header always set Strict-Transport-Security &quot;max-age=31536000; includeSubDomains&quot;\r\n  Header set Referrer-Policy &quot;strict-origin-when-cross-origin&quot;\r\n  Header set Permissions-Policy &quot;camera=(), microphone=(), geolocation=()&quot;\r\n&lt;\/IfModule&gt;\r\n\r\n# wp-includes\u5185\u306ePHP\u3092\u76f4\u63a5\u5b9f\u884c\u7981\u6b62\r\n&lt;IfModule mod_rewrite.c&gt;\r\n  RewriteEngine On\r\n  RewriteBase \/\r\n  RewriteRule ^wp-admin\/includes\/ - &lsqb;F,L&rsqb;\r\n  RewriteRule !^wp-includes\/ - &lsqb;S=3&rsqb;\r\n  RewriteRule ^wp-includes\/&lsqb;^\/&rsqb;+\\.php$ - &lsqb;F,L&rsqb;\r\n  RewriteRule ^wp-includes\/js\/tinymce\/langs\/.+\\.php - &lsqb;F,L&rsqb;\r\n  RewriteRule ^wp-includes\/theme-compat\/ - &lsqb;F,L&rsqb;\r\n&lt;\/IfModule&gt;\r\n\r\n# HTTPS\u5f37\u5236\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\r\nRewriteEngine on\r\nRewriteCond %{HTTPS} off\r\nRewriteRule ^(.*)$ https:\/\/%{HTTP_HOST}%{REQUEST_URI} &lsqb;R=301,L&rsqb;\r\n\r\n# GZIP\u5727\u7e2e\r\n&lt;IfModule mod_deflate.c&gt;\r\nSetOutputFilter DEFLATE\r\nBrowserMatch ^Mozilla\/4 gzip-only-text\/html\r\nBrowserMatch ^Mozilla\/4\\.0&lsqb;678&rsqb; no-gzip\r\nBrowserMatch \\bMSI&lsqb;E&rsqb; !no-gzip !gzip-only-text\/html\r\nSetEnvIfNoCase Request_URI \\.(?:gif|jpe?g|png|ico)$ no-gzip dont-vary\r\nSetEnvIfNoCase Request_URI _\\.utxt$ no-gzip\r\nAddOutputFilterByType DEFLATE text\/plain\r\nAddOutputFilterByType DEFLATE text\/html\r\nAddOutputFilterByType DEFLATE text\/xml\r\nAddOutputFilterByType DEFLATE text\/css\r\nAddOutputFilterByType DEFLATE application\/xhtml+xml\r\nAddOutputFilterByType DEFLATE application\/xml\r\nAddOutputFilterByType DEFLATE application\/rss+xml\r\nAddOutputFilterByType DEFLATE application\/atom_xml\r\nAddOutputFilterByType DEFLATE application\/x-javascript\r\nAddOutputFilterByType DEFLATE application\/x-httpd-php\r\n&lt;\/IfModule&gt;\r\n\r\n# BEGIN WordPress\r\n&lt;IfModule mod_rewrite.c&gt;\r\n  RewriteEngine On\r\n  RewriteRule .* - &lsqb;E=HTTP_AUTHORIZATION:%{HTTP:Authorization}&rsqb;\r\n  RewriteBase \/\r\n  RewriteRule ^index\\.php$ - &lsqb;L&rsqb;\r\n  RewriteCond %{REQUEST_FILENAME} !-f\r\n  RewriteCond %{REQUEST_FILENAME} !-d\r\n  RewriteRule . \/index.php &lsqb;L&rsqb;\r\n&lt;\/IfModule&gt;\r\n# END WordPress\r\n<\/code><\/pre>\r\n<blockquote class=\"mt-0.75r\">\r\n<p><b class=\"bold\"><code>BEGIN WordPress<\/code> \uff5e <code>END WordPress<\/code> \u306e\u9593\u306f\u89e6\u3089\u306a\u3044\u3053\u3068\u3002<\/b> WordPress\u304c\u81ea\u52d5\u66f4\u65b0\u3059\u308b\u30d6\u30ed\u30c3\u30af\u3067\u3059\u3002\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u8a2d\u5b9a\u306f\u5fc5\u305a\u3053\u306e\u30d6\u30ed\u30c3\u30af\u306e<b class=\"bold\">\u4e0a<\/b>\u306b\u8a18\u8ff0\u3057\u307e\u3059\u3002<\/p>\r\n<\/blockquote>\r\n<h2 class=\"fz-xl\">\u3055\u3089\u306b\u5f37\u56fa\u306b\u3059\u308b\u306b\u306f<\/h2>\r\n<p><code>.htaccess<\/code> \u306e\u8a2d\u5b9a\u306b\u52a0\u3048\u3066\u3001\u4ee5\u4e0b\u3082\u3042\u308f\u305b\u3066\u884c\u3046\u3068\u3088\u308a\u5b89\u5168\u3067\u3059\u3002<\/p>\r\n<ul style=\"list-style-type:bullet;\" class=\"my-0.5r\">\r\n<li><b class=\"bold\">\u30ed\u30b0\u30a4\u30f3URL\u306e\u5909\u66f4<\/b>\uff08\u30c7\u30d5\u30a9\u30eb\u30c8\u306e <code>wp-login.php<\/code> \u3092\u975e\u516c\u958b\u306b\u3059\u308b\uff09<\/li>\r\n<li><b class=\"bold\">\u30ed\u30b0\u30a4\u30f3\u8a66\u884c\u306e\u5236\u9650<\/b>\uff08Solid Security \u306a\u3069\u306e\u30d7\u30e9\u30b0\u30a4\u30f3\u3067\uff09<\/li>\r\n<li><b class=\"bold\">\u30d7\u30e9\u30b0\u30a4\u30f3\u30fb\u30c6\u30fc\u30de\u306e\u5b9a\u671f\u66f4\u65b0<\/b>\uff08\u8106\u5f31\u6027\u306e\u591a\u304f\u306f\u53e4\u3044\u30d0\u30fc\u30b8\u30e7\u30f3\u306b\u8d77\u56e0\uff09<\/li>\r\n<li><b class=\"bold\">\u4e0d\u8981\u306a\u30d7\u30e9\u30b0\u30a4\u30f3\u306e\u524a\u9664<\/b>\uff08\u7121\u52b9\u5316\u3060\u3051\u3067\u306f\u4e0d\u5341\u5206\u3001\u5b8c\u5168\u524a\u9664\u3092\uff09<\/li>\r\n<\/ul>\r\n<p>\u3053\u308c\u3089\u306e\u5bfe\u7b56\u306b\u3064\u3044\u3066\u306f\u3001\u5225\u8a18\u4e8b\u3067\u8a73\u3057\u304f\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>","protected":false},"excerpt":{"rendered":"WordPress\u30b5\u30a4\u30c8\u3078\u306e\u4e0d\u6b63\u30a2\u30af\u30bb\u30b9\u3092\u9632\u3050\u300c.htaccess\u300d\u306e\u8a2d\u5b9a\u65b9\u6cd5\u3092\u5fb9\u5e95\u89e3\u8aac\u3002\u91cd\u8981\u30d5\u30a1\u30a4\u30eb\u306e\u4fdd\u8b77\u30fb\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u30ea\u30b9\u30c6\u30a3\u30f3\u30b0\u9632\u6b62\u30fb\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30d8\u30c3\u30c0\u30fc\u8a2d\u5b9a\u306a\u3069\u3001\u30b3\u30d4\u30da\u3067\u4f7f\u3048\u308b\u30b3\u30fc\u30c9\u3064\u304d\u3067\u7d39\u4ecb\u3057\u307e\u3059\u3002","protected":false},"author":1,"featured_media":11162,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[13],"tags":[724,725,723,726,721,722,419,415,159,102],"class_list":{"0":"post-11151","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-wordpress","8":"tag-724","9":"tag-725","10":"tag-723","11":"tag-726","12":"tag-htaccess","13":"tag-wordpress","14":"tag-web","15":"tag-waf","16":"tag-159"},"_links":{"self":[{"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/posts\/11151","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/comments?post=11151"}],"version-history":[{"count":3,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/posts\/11151\/revisions"}],"predecessor-version":[{"id":11173,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/posts\/11151\/revisions\/11173"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/media\/11162"}],"wp:attachment":[{"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/media?parent=11151"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/categories?post=11151"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/tags?post=11151"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}