{"id":68,"date":"2024-09-08T16:51:50","date_gmt":"2024-09-08T07:51:50","guid":{"rendered":"https:\/\/dexall.co.jp\/articles\/?p=68"},"modified":"2025-03-24T08:55:09","modified_gmt":"2025-03-23T23:55:09","slug":"carrierwave%e3%83%9e%e3%82%b9%e3%82%bf%e3%83%bc%e3%82%ac%e3%82%a4%e3%83%89%ef%bc%9aruby%e3%81%a7%e5%ae%9f%e7%8f%be%e3%81%99%e3%82%8b%e6%9c%80%e5%bc%b7%e3%81%ae%e3%83%95%e3%82%a1%e3%82%a4%e3%83%ab","status":"publish","type":"post","link":"https:\/\/dexall.co.jp\/articles\/?p=68","title":{"rendered":"CarrierWave\u30de\u30b9\u30bf\u30fc\u30ac\u30a4\u30c9\uff1aRuby\u3067\u5b9f\u73fe\u3059\u308b\u6700\u5f37\u306e\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6a5f\u80fd"},"content":{"rendered":"\n<p>CarrierWave\u306f\u3001Ruby\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306b\u304a\u3051\u308b\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6a5f\u80fd\u3092\u7c21\u5358\u304b\u3064\u67d4\u8edf\u306b\u5b9f\u88c5\u3067\u304d\u308b\u5f37\u529b\u306aGem\u3067\u3059\u3002<br>\u672c\u8a18\u4e8b\u3067\u306f\u3001CarrierWave\u306e\u57fa\u672c\u7684\u306a\u4f7f\u3044\u65b9\u304b\u3089\u9ad8\u5ea6\u306a\u5b9f\u88c5\u30c6\u30af\u30cb\u30c3\u30af\u3001\u3055\u3089\u306b\u306f\u5b9f\u8df5\u7684\u306a\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u4f8b\u307e\u3067\u3001\u5305\u62ec\u7684\u306b\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-block-simple sgb-box-simple sgb-box-simple--title-normal sgb-box-simple--with-border\"><div style=\"background-color:var(--wp--preset--color--sango-main);color:#FFF\" class=\"sgb-box-simple__title\">\u3053\u306e\u8a18\u4e8b\u3092\u901a\u3057\u3066\u7406\u89e3\u3067\u304d\u308b9\u3064\u306e\u3053\u3068<\/div><div class=\"sgb-box-simple__body\" style=\"border-color:var(--wp--preset--color--sango-main);background-color:#FFF\">\n<ul class=\"wp-block-list\">\n<li>CarrierWave\u306e\u57fa\u672c\u7684\u306a\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u3068\u8a2d\u5b9a\u65b9\u6cd5<\/li>\n\n\n\n<li>\u5358\u4e00\u30fb\u8907\u6570\u30d5\u30a1\u30a4\u30eb\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u5b9f\u88c5\u30c6\u30af\u30cb\u30c3\u30af<\/li>\n\n\n\n<li>\u753b\u50cf\u51e6\u7406\u6a5f\u80fd\u306e\u6d3b\u7528\u6cd5\u3068\u6700\u9069\u5316\u30c6\u30af\u30cb\u30c3\u30af<\/li>\n\n\n\n<li>\u9ad8\u5ea6\u306a\u8a2d\u5b9a\u3068\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u30aa\u30d7\u30b7\u30e7\u30f3<\/li>\n\n\n\n<li>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/li>\n\n\n\n<li>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u306e\u624b\u6cd5<\/li>\n\n\n\n<li>\u4ed6\u306eGem\u3068\u306e\u9023\u643a\u6d3b\u7528\u6cd5<\/li>\n\n\n\n<li>\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u3068\u30c7\u30d0\u30c3\u30b0\u624b\u6cd5<\/li>\n\n\n\n<li>\u5b9f\u8df5\u7684\u306a\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u4f8b\u3068\u5fdc\u7528\u30b7\u30ca\u30ea\u30aa<\/li>\n<\/ul>\n<\/div><\/div>\n\n\n\n<div class=\"toc\"><br \/>\n<b>Warning<\/b>:  Undefined array key \"is_admin\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>116<\/b><br \/>\n<br \/>\n<b>Warning<\/b>:  Undefined array key \"is_category_top\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>121<\/b><br \/>\n<br \/>\n<b>Warning<\/b>:  Undefined array key \"is_top\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>128<\/b><br \/>\n    <div id=\"toc_container\" class=\"sgb-toc--bullets js-smooth-scroll\" data-dialog-title=\"\u76ee\u6b21\">\n      <p class=\"toc_title\">\u76ee\u6b21 <\/p>\n      <ul class=\"toc_list\">  <li class=\"first\">    <a href=\"#i-0\">CarrierWave\u3068\u306f\uff1fRuby\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306e\u9769\u547d\u5150<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-1\">\u30b7\u30f3\u30d7\u30eb\u3055\u3068\u67d4\u8edf\u6027\u3092\u517c\u306d\u5099\u3048\u305fGem<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-2\">ActiveRecord\u3068\u306e\u512a\u308c\u305f\u7d71\u5408\u6027<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-3\">CarrierWave\u306e\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u3068\u57fa\u672c\u8a2d\u5b9a<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-4\">Gemfile\u3078\u306e\u8ffd\u52a0\u3068\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u624b\u9806<\/a>      <\/li>      <li>        <a href=\"#i-5\">\u30a2\u30c3\u30d7\u30ed\u30fc\u30c0\u30fc\u30af\u30e9\u30b9\u306e\u4f5c\u6210\u3068\u8a2d\u5b9a<\/a>      <\/li>      <li>        <a href=\"#i-6\">\u30e2\u30c7\u30eb\u3068\u306e\u95a2\u9023\u4ed8\u3051\u65b9\u6cd5<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-7\">\u3088\u304f\u4f7f\u7528\u3055\u308c\u308b\u521d\u671f\u8a2d\u5b9a\u30aa\u30d7\u30b7\u30e7\u30f3<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-12\">\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306e\u5b9f\u88c5\u30c6\u30af\u30cb\u30c3\u30af<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-13\">\u5358\u4e00\u30d5\u30a1\u30a4\u30eb\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u51e6\u7406<\/a>      <\/li>      <li>        <a href=\"#i-17\">\u8907\u6570\u30d5\u30a1\u30a4\u30eb\u306e\u540c\u6642\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u5bfe\u5fdc<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-21\">\u30c9\u30e9\u30c3\u30b0\uff06\u30c9\u30ed\u30c3\u30d7\u306b\u3088\u308b\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9UX\u306e\u5411\u4e0a<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-25\">\u753b\u50cf\u51e6\u7406\u6a5f\u80fd\u306e\u6d3b\u7528\u6cd5<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-26\">\u30b5\u30e0\u30cd\u30a4\u30eb\u751f\u6210\u306b\u3088\u308b\u8868\u793a\u306e\u6700\u9069\u5316<\/a>      <\/li>      <li>        <a href=\"#i-27\">\u753b\u50cf\u30ea\u30b5\u30a4\u30ba\u3068\u5f62\u5f0f\u5909\u63db\u306e\u30c6\u30af\u30cb\u30c3\u30af<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-31\">\u753b\u50cf\u306e\u54c1\u8cea\u8abf\u6574\u3068\u30d5\u30a1\u30a4\u30eb\u30b5\u30a4\u30ba\u6700\u9069\u5316<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-32\">\u9ad8\u5ea6\u306a\u8a2d\u5b9a\u3068\u30ab\u30b9\u30bf\u30de\u30a4\u30ba<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-33\">\u30b9\u30c8\u30ec\u30fc\u30b8\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u306e\u9078\u629e\u3068\u8a2d\u5b9a<\/a>      <\/li>      <li>        <a href=\"#i-34\">\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u524d\u5f8c\u306e\u51e6\u7406\u3092\u30d5\u30c3\u30af\u3067\u5236\u5fa1<\/a>      <\/li>      <li>        <a href=\"#i-35\">\u72ec\u81ea\u306e\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u30eb\u30fc\u30eb\u306e\u5b9f\u88c5\u65b9\u6cd5<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-39\">\u305d\u306e\u4ed6\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u4f8b<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-42\">\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-43\">\u8a31\u53ef\u3059\u308b\u30d5\u30a1\u30a4\u30eb\u5f62\u5f0f\u306e\u5236\u9650\u8a2d\u5b9a<\/a>      <\/li>      <li>        <a href=\"#i-44\">\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u30b5\u30a4\u30ba\u306e\u5236\u9650\u3068DDoS\u5bfe\u7b56<\/a>      <\/li>      <li>        <a href=\"#i-45\">\u30d5\u30a1\u30a4\u30eb\u540d\u306e\u30b5\u30cb\u30bf\u30a4\u30ba\u306b\u3088\u308b\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5f37\u5316<\/a>      <\/li>      <li>        <a href=\"#i-46\">\u305d\u306e\u4ed6\u306e\u91cd\u8981\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-50\">CarrierWave\u4f7f\u7528\u6642\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-51\">\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u30c6\u30af\u30cb\u30c3\u30af<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-52\">\u975e\u540c\u671f\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306b\u3088\u308b\u5fdc\u7b54\u6027\u5411\u4e0a<\/a>      <\/li>      <li>        <a href=\"#i-53\">CDN\u3092\u6d3b\u7528\u3057\u305f\u30b3\u30f3\u30c6\u30f3\u30c4\u914d\u4fe1\u306e\u9ad8\u901f\u5316<\/a>      <\/li>      <li>        <a href=\"#i-54\">\u30ad\u30e3\u30c3\u30b7\u30e5\u6226\u7565\u306b\u3088\u308b\u30ed\u30fc\u30c9\u6642\u9593\u306e\u77ed\u7e2e<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-55\">\u305d\u306e\u4ed6\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u30c6\u30af\u30cb\u30c3\u30af<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-60\">CarrierWave\u3068\u4ed6\u306eGem\u306e\u9023\u643a\u6d3b\u7528\u6cd5<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-61\">Fog Gem\u3092\u4f7f\u7528\u3057\u305f\u30af\u30e9\u30a6\u30c9\u30b9\u30c8\u30ec\u30fc\u30b8\u3068\u306e\u7d71\u5408<\/a>      <\/li>      <li>        <a href=\"#i-62\">MiniMagick\u306b\u3088\u308b\u9ad8\u5ea6\u306a\u753b\u50cf\u52a0\u5de5\u306e\u5b9f\u73fe<\/a>      <\/li>      <li>        <a href=\"#i-63\">CarrierWave Direct\u3067S3\u3078\u306e\u76f4\u63a5\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-64\">\u305d\u306e\u4ed6\u306e\u9023\u643a\u4f8b<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-67\">\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u3068\u30c7\u30d0\u30c3\u30b0\u624b\u6cd5<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-68\">\u3088\u304f\u3042\u308b\u30a8\u30e9\u30fc\u3068\u305d\u306e\u89e3\u6c7a\u7b56<\/a>      <\/li>      <li>        <a href=\"#i-72\">\u30ed\u30b0\u3068\u30c7\u30d0\u30c3\u30b0\u51fa\u529b\u306e\u6d3b\u7528\u65b9\u6cd5<\/a>      <\/li>      <li>        <a href=\"#i-73\">\u30c6\u30b9\u30c8\u74b0\u5883\u3067\u306e\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306e\u30e2\u30c3\u30af\u5316<\/a>      <\/li>      <li>        <a href=\"#i-74\">CarrierWave\u7279\u6709\u306e\u30c7\u30d0\u30c3\u30b0\u30c6\u30af\u30cb\u30c3\u30af<\/a>      <\/li>      <li>        <a href=\"#i-77\">\u4e00\u822c\u7684\u306a\u30c7\u30d0\u30c3\u30b0\u30c4\u30fc\u30eb\u306e\u6d3b\u7528<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-78\">\u30b7\u30b9\u30c6\u30de\u30c6\u30a3\u30c3\u30af\u306a\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u30a2\u30d7\u30ed\u30fc\u30c1<\/a>      <\/li>    <\/ul>  <\/li>  <li class=\"last\">    <a href=\"#i-79\">CarrierWave\u3092\u4f7f\u3063\u305f\u5b9f\u8df5\u7684\u306a\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u4f8b<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-80\">\u30e6\u30fc\u30b6\u30fc\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u50cf\u6a5f\u80fd\u306e\u5b9f\u88c5<\/a>      <\/li>      <li>        <a href=\"#i-81\">\u8907\u6570\u753b\u50cf\u3092\u6271\u3046\u5546\u54c1\u30ab\u30bf\u30ed\u30b0\u30b7\u30b9\u30c6\u30e0\u306e\u69cb\u7bc9<\/a>      <\/li>      <li>        <a href=\"#i-82\">\u5927\u5bb9\u91cf\u30d5\u30a1\u30a4\u30eb\u5171\u6709\u30b5\u30fc\u30d3\u30b9\u306e\u958b\u767a\u4e8b\u4f8b<\/a>      <\/li>      <li>        <a href=\"#i-83\">\u6ce8\u610f\u70b9\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-84\">\u30d3\u30b8\u30cd\u30b9\u30b7\u30fc\u30f3\u3067\u306e\u5fdc\u7528\u4f8b<\/a>      <\/li>    <\/ul>  <\/li><\/ul>\n      <a href=\"#\" class=\"sgb-toc-button js-toc-button\" rel=\"nofollow\" data-open-dialog=\"true\"><i class=\"fa fa-list\"><\/i><span class=\"sgb-toc-button__text\">\u76ee\u6b21\u3078<\/span><\/a>\n    <\/div><\/div><h2 class=\"wp-block-sgb-headings sgb-heading\" id=\"i-0\"><span class=\"sgb-heading__inner sgb-heading--type1 with-icon\" style=\"background-color:transparent;border-color:transparent;font-size:1.2em\"><i class=\"fa fa-check\" style=\"color:var(--wp--preset--color--sango-main)\"><\/i><span class=\"sgb-heading__text\" style=\"color:#333\">CarrierWave\u3068\u306f\uff1fRuby\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306e\u9769\u547d\u5150<\/span><\/span><\/h2>\n\n\n\n<p>CarrierWave\u306f\u3001Ruby\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u958b\u767a\u306b\u304a\u3051\u308b\u753b\u671f\u7684\u306a\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u30bd\u30ea\u30e5\u30fc\u30b7\u30e7\u30f3\u3067\u3059\u3002<br>\u3053\u306eGem\u306f\u3001\u30b7\u30f3\u30d7\u30eb\u3055\u3068\u67d4\u8edf\u6027\u3092\u517c\u306d\u5099\u3048\u3001Ruby\u30a8\u30b3\u30b7\u30b9\u30c6\u30e0\u306b\u304a\u3044\u3066\u4e0d\u53ef\u6b20\u306a\u5b58\u5728\u3068\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-1\">\u30b7\u30f3\u30d7\u30eb\u3055\u3068\u67d4\u8edf\u6027\u3092\u517c\u306d\u5099\u3048\u305fGem<\/h3>\n\n\n\n<p>CarrierWave\u306e\u6700\u5927\u306e\u7279\u5fb4\u306f\u3001\u305d\u306e\u4f7f\u3044\u3084\u3059\u3055\u3068\u9ad8\u5ea6\u306a\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u6027\u306e\u4e21\u7acb\u3067\u3059\u3002<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u7c21\u5358\u306a\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\uff1a\u6570\u884c\u306e\u30b3\u30fc\u30c9\u3067\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6a5f\u80fd\u3092\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u67d4\u8edf\u306a\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\uff1a\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u51e6\u7406\u3084\u4fdd\u5b58\u5148\u306e\u7d30\u304b\u306a\u5236\u5fa1\u304c\u53ef\u80fd\u3067\u3059\u3002<\/li>\n\n\n\n<li>\u591a\u69d8\u306a\u30b9\u30c8\u30ec\u30fc\u30b8\u30aa\u30d7\u30b7\u30e7\u30f3\uff1a\u30ed\u30fc\u30ab\u30eb\u30d5\u30a1\u30a4\u30eb\u30b7\u30b9\u30c6\u30e0\u3060\u3051\u3067\u306a\u304f\u3001AmazonS3\u3084Google Cloud Storage\u306a\u3069\u3001\u69d8\u3005\u306a\u30af\u30e9\u30a6\u30c9\u30b9\u30c8\u30ec\u30fc\u30b8\u306b\u3082\u5bfe\u5fdc\u3057\u3066\u3044\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u753b\u50cf\u51e6\u7406\u306e\u7d71\u5408\uff1aRMagick\u3084MiniMagick\u306a\u3069\u306e\u753b\u50cf\u51e6\u7406\u30e9\u30a4\u30d6\u30e9\u30ea\u3068\u9023\u643a\u3057\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6642\u306e\u753b\u50cf\u52a0\u5de5\u304c\u53ef\u80fd\u3067\u3059\u3002<\/li>\n<\/ol>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u7279\u5fb4\u306b\u3088\u308a\u3001\u958b\u767a\u8005\u306f\u77ed\u6642\u9593\u3067\u57fa\u672c\u7684\u306a\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6a5f\u80fd\u3092\u5b9f\u88c5\u3057\u3064\u3064\u3001\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u9ad8\u5ea6\u306a\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u3092\u884c\u3046\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-2\">ActiveRecord\u3068\u306e\u512a\u308c\u305f\u7d71\u5408\u6027<\/h3>\n\n\n\n<p>CarrierWave\u306e\u3082\u3046\u4e00\u3064\u306e\u5f37\u307f\u306f\u3001ActiveRecord\u3068\u306e\u512a\u308c\u305f\u7d71\u5408\u6027\u3067\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class User &lt; ApplicationRecord\n  mount_uploader :avatar, AvatarUploader\nend\n\n# \u4f7f\u7528\u4f8b\nuser = User.new\nuser.avatar = params[:file] # \u30d5\u30a1\u30a4\u30eb\u3092\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\nuser.save!\nuser.avatar.url # =&gt; '\/uploads\/user\/avatar\/1\/file.jpg'\nuser.avatar.current_path # =&gt; 'path\/to\/file.jpg'\nuser.avatar? # =&gt; true<\/pre>\n\n\n\n<p>\u3053\u306e\u3088\u3046\u306b\u3001\u30e2\u30c7\u30eb\u306b\u76f4\u63a5\u30a2\u30c3\u30d7\u30ed\u30fc\u30c0\u30fc\u3092\u30de\u30a6\u30f3\u30c8\u3067\u304d\u3001ActiveRecord\u306e\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u3084\u30b3\u30fc\u30eb\u30d0\u30c3\u30af\u3068\u9023\u643a\u304c\u53ef\u80fd\u3067\u3059\u3002\u3053\u308c\u306b\u3088\u308a\u3001\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u51e6\u7406\u3092\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30d3\u30b8\u30cd\u30b9\u30ed\u30b8\u30c3\u30af\u306b\u81ea\u7136\u306b\u7d44\u307f\u8fbc\u3080\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>CarrierWave\u306f\u3001\u4ed6\u306e\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u30e9\u30a4\u30d6\u30e9\u30ea\u3068\u6bd4\u8f03\u3057\u3066\u3082\u3001\u591a\u304f\u306e\u5229\u70b9\u304c\u3042\u308a\u307e\u3059\u3002<br>\u4f8b\u3048\u3070\u3001\u304b\u3064\u3066\u4eba\u6c17\u3060\u3063\u305fPaperclip\u306f\u3059\u3067\u306b\u30e1\u30f3\u30c6\u30ca\u30f3\u30b9\u304c\u7d42\u4e86\u3057\u3066\u3044\u307e\u3059\u304c\u3001CarrierWave\u306f\u6d3b\u767a\u306b\u958b\u767a\u304c\u7d9a\u3051\u3089\u308c\u3066\u3044\u307e\u3059\u3002<br>\u307e\u305f\u3001\u3088\u308a\u65b0\u3057\u3044Shrine\u3068\u6bd4\u3079\u308b\u3068\u3001CarrierWave\u306f\u8a2d\u5b9a\u304c\u7c21\u5358\u3067\u3001\u591a\u304f\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306e\u4f7f\u7528\u5b9f\u7e3e\u304c\u3042\u308b\u3068\u3044\u3046\u5f37\u307f\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<p>CarrierWave\u306f\u3001\u305d\u306e\u9769\u65b0\u7684\u306a\u6a5f\u80fd\u3068\u4f7f\u3044\u3084\u3059\u3055\u306b\u3088\u308a\u3001Ruby\u3067\u306e\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u51e6\u7406\u306b\u9769\u547d\u3092\u3082\u305f\u3089\u3057\u307e\u3057\u305f\u3002<br>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3053\u306e\u30d1\u30ef\u30d5\u30eb\u306aGem\u306e\u5177\u4f53\u7684\u306a\u4f7f\u3044\u65b9\u3092\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-sgb-headings sgb-heading\" id=\"i-3\"><span class=\"sgb-heading__inner sgb-heading--type1 with-icon\" style=\"background-color:transparent;border-color:transparent;font-size:1.2em\"><i class=\"fa fa-check\" style=\"color:var(--wp--preset--color--sango-main)\"><\/i><span class=\"sgb-heading__text\" style=\"color:#333\">CarrierWave\u306e\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u3068\u57fa\u672c\u8a2d\u5b9a<\/span><\/span><\/h2>\n\n\n\n<p>CarrierWave\u3092\u4f7f\u3044\u59cb\u3081\u308b\u306e\u306f\u975e\u5e38\u306b\u7c21\u5358\u3067\u3059\u3002<br>\u3053\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001CarrierWave\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u304b\u3089\u57fa\u672c\u7684\u306a\u8a2d\u5b9a\u307e\u3067\u3001\u30b9\u30c6\u30c3\u30d7\u30d0\u30a4\u30b9\u30c6\u30c3\u30d7\u3067\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-4\">Gemfile\u3078\u306e\u8ffd\u52a0\u3068\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u624b\u9806<\/h3>\n\n\n\n<p>\u307e\u305a\u3001\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306eGemfile\u306bCarrierWave\u3092\u8ffd\u52a0\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">gem 'carrierwave', '~&gt; 2.0'<\/pre>\n\n\n\n<p>\u6b21\u306b\u3001\u30bf\u30fc\u30df\u30ca\u30eb\u3067\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3092\u5b9f\u884c\u3057\u3066\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">bundle install<\/pre>\n\n\n\n<p>\u753b\u50cf\u51e6\u7406\u3092\u884c\u3046\u5834\u5408\u306f\u3001\u8ffd\u52a0\u3067MiniMagick\u306a\u3069\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u3082\u5fc5\u8981\u3067\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">gem 'mini_magick'<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-5\">\u30a2\u30c3\u30d7\u30ed\u30fc\u30c0\u30fc\u30af\u30e9\u30b9\u306e\u4f5c\u6210\u3068\u8a2d\u5b9a<\/h3>\n\n\n\n<p>CarrierWave\u306e\u4e2d\u5fc3\u3068\u306a\u308b\u306e\u304c\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c0\u30fc\u30af\u30e9\u30b9\u3067\u3059\u3002\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3067\u751f\u6210\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">rails generate uploader Avatar<\/pre>\n\n\n\n<p>\u751f\u6210\u3055\u308c\u305f\u30a2\u30c3\u30d7\u30ed\u30fc\u30c0\u30fc\u30af\u30e9\u30b9\uff08app\/uploaders\/avatar_uploader.rb\uff09\u306b\u3001\u57fa\u672c\u7684\u306a\u8a2d\u5b9a\u3092\u8ffd\u52a0\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class AvatarUploader &lt; CarrierWave::Uploader::Base\n  # \u30b9\u30c8\u30ec\u30fc\u30b8\u306e\u9078\u629e\uff08:file\u306f\u30ed\u30fc\u30ab\u30eb\u30d5\u30a1\u30a4\u30eb\u30b7\u30b9\u30c6\u30e0\u3001:fog\u306f\u30af\u30e9\u30a6\u30c9\u30b9\u30c8\u30ec\u30fc\u30b8\uff09\n  storage :file\n\n  # \u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u30d5\u30a1\u30a4\u30eb\u306e\u4fdd\u5b58\u5148\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\n  def store_dir\n    \"uploads\/#{model.class.to_s.underscore}\/#{mounted_as}\/#{model.id}\"\n  end\n\n  # \u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u53ef\u80fd\u306a\u62e1\u5f35\u5b50\u306e\u30ea\u30b9\u30c8\n  def extension_allowlist\n    %w(jpg jpeg gif png)\n  end\n\n  # \u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u305f\u30d5\u30a1\u30a4\u30eb\u306e\u30d5\u30a1\u30a4\u30eb\u540d\u3092\u5909\u66f4\n  def filename\n    \"something.jpg\" if original_filename\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u8a2d\u5b9a\u306b\u3088\u308a\u3001\u57fa\u672c\u7684\u306a\u30d5\u30a1\u30a4\u30eb\u306e\u4fdd\u5b58\u5834\u6240\u3084\u8a31\u53ef\u3059\u308b\u62e1\u5f35\u5b50\u306a\u3069\u3092\u5236\u5fa1\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-6\">\u30e2\u30c7\u30eb\u3068\u306e\u95a2\u9023\u4ed8\u3051\u65b9\u6cd5<\/h3>\n\n\n\n<p>\u30a2\u30c3\u30d7\u30ed\u30fc\u30c0\u30fc\u3092\u4f5c\u6210\u3057\u305f\u3089\u3001\u305d\u308c\u3092\u30e2\u30c7\u30eb\u3068\u95a2\u9023\u4ed8\u3051\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class User &lt; ApplicationRecord\n  mount_uploader :avatar, AvatarUploader\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u95a2\u9023\u4ed8\u3051\u306b\u3088\u308a\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u5229\u70b9\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-block-simple sgb-box-simple sgb-box-simple--title-normal sgb-box-simple--with-border\"><div style=\"background-color:var(--wp--preset--color--sango-main);color:#FFF\" class=\"sgb-box-simple__title\">CarrierWave\u306e3\u3064\u306e\u5229\u70b9<\/div><div class=\"sgb-box-simple__body\" style=\"border-color:var(--wp--preset--color--sango-main);background-color:#FFF\">\n<ol class=\"wp-block-list\">\n<li>ActiveRecord\u3068\u306e\u81ea\u7136\u306a\u7d71\u5408<\/li>\n\n\n\n<li>\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u306e\u9069\u7528\u304c\u5bb9\u6613\uff08\u4f8b\uff1a\u30d5\u30a1\u30a4\u30eb\u30b5\u30a4\u30ba\u3084\u5f62\u5f0f\u306e\u5236\u9650\uff09<\/li>\n\n\n\n<li>\u30d5\u30a1\u30a4\u30eb\u306e\u7ba1\u7406\u304c\u7c21\u5358\uff08\u4fdd\u5b58\u3001\u66f4\u65b0\u3001\u524a\u9664\u304c\u81ea\u52d5\u7684\u306b\u51e6\u7406\u3055\u308c\u308b\uff09<\/li>\n<\/ol>\n<\/div><\/div>\n\n\n\n<p>\u4f7f\u7528\u4f8b\u3092\u4ee5\u4e0b\u306b\u8a18\u8f09\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">user = User.new\nuser.avatar = params[:file] # \u30d5\u30a1\u30a4\u30eb\u3092\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\nuser.save!\nuser.avatar.url # =&gt; '\/uploads\/user\/avatar\/1\/file.jpg'<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-7\">\u3088\u304f\u4f7f\u7528\u3055\u308c\u308b\u521d\u671f\u8a2d\u5b9a\u30aa\u30d7\u30b7\u30e7\u30f3<\/h3>\n\n\n\n<p>CarrierWave\u306b\u306f\u591a\u304f\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u30aa\u30d7\u30b7\u30e7\u30f3\u304c\u3042\u308a\u307e\u3059\u3002<br>\u4ee5\u4e0b\u306f\u983b\u7e41\u306b\u4f7f\u7528\u3055\u308c\u308b\u8a2d\u5b9a\u4f8b\u3067\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-8\">\u30c7\u30d5\u30a9\u30eb\u30c8\u306e\u4fdd\u5b58\u5148\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306e\u5909\u66f4<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   def store_dir\n     \"custom\/upload\/path\/#{model.id}\"\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-9\">\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u53ef\u80fd\u306a\u30d5\u30a1\u30a4\u30eb\u30b5\u30a4\u30ba\u306e\u5236\u9650<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   def size_range\n     1.byte..5.megabytes\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-10\">\u753b\u50cf\u306e\u30ea\u30b5\u30a4\u30ba\u8a2d\u5b9a\uff08MiniMagick\u3092\u4f7f\u7528\uff09<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   include CarrierWave::MiniMagick\n\n   process resize_to_fit: [800, 800]<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-11\">\u30d5\u30a1\u30a4\u30eb\u540d\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   def filename\n     \"#{secure_token}.#{file.extension}\" if original_filename.present?\n   end\n\n   protected\n   def secure_token\n     var = :\"@#{mounted_as}_secure_token\"\n     model.instance_variable_get(var) or model.instance_variable_set(var, SecureRandom.uuid)\n   end<\/pre>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u8a2d\u5b9a\u3092\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u8981\u4ef6\u306b\u5408\u308f\u305b\u305f\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6a5f\u80fd\u3092\u5b9f\u73fe\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>CarrierWave\u306e\u57fa\u672c\u7684\u306a\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u3068\u8a2d\u5b9a\u306f\u4ee5\u4e0a\u3067\u3059\u3002<br>\u3053\u308c\u3089\u306e\u624b\u9806\u3092\u8e0f\u3080\u3053\u3068\u3067\u3001Ruby\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306b\u5805\u7262\u3067\u67d4\u8edf\u306a\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6a5f\u80fd\u3092\u7c21\u5358\u306b\u8ffd\u52a0\u3067\u304d\u307e\u3059\u3002<br>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3088\u308a\u5177\u4f53\u7684\u306a\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306e\u5b9f\u88c5\u30c6\u30af\u30cb\u30c3\u30af\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-sgb-headings sgb-heading\" id=\"i-12\"><span class=\"sgb-heading__inner sgb-heading--type1 with-icon\" style=\"background-color:transparent;border-color:transparent;font-size:1.2em\"><i class=\"fa fa-check\" style=\"color:var(--wp--preset--color--sango-main)\"><\/i><span class=\"sgb-heading__text\" style=\"color:#333\">\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306e\u5b9f\u88c5\u30c6\u30af\u30cb\u30c3\u30af<\/span><\/span><\/h2>\n\n\n\n<p>CarrierWave\u3092\u4f7f\u7528\u3057\u305f\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306e\u5b9f\u88c5\u306b\u306f\u3001\u69d8\u3005\u306a\u30c6\u30af\u30cb\u30c3\u30af\u304c\u3042\u308a\u307e\u3059\u3002<br>\u3053\u3053\u3067\u306f\u3001\u5358\u4e00\u30d5\u30a1\u30a4\u30eb\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3001\u8907\u6570\u30d5\u30a1\u30a4\u30eb\u306e\u540c\u6642\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3001\u305d\u3057\u3066\u30c9\u30e9\u30c3\u30b0\uff06\u30c9\u30ed\u30c3\u30d7\u306b\u3088\u308b\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306e\u5b9f\u88c5\u65b9\u6cd5\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-13\">\u5358\u4e00\u30d5\u30a1\u30a4\u30eb\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u51e6\u7406<\/h3>\n\n\n\n<p>\u5358\u4e00\u30d5\u30a1\u30a4\u30eb\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306f\u3001CarrierWave\u306e\u57fa\u672c\u7684\u306a\u4f7f\u7528\u65b9\u6cd5\u3067\u3059\u3002<br>\u4ee5\u4e0b\u306e\u624b\u9806\u3067\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-14\">\u30d3\u30e5\u30fc\u306b\u30d5\u30a1\u30a4\u30eb\u30d5\u30a3\u30fc\u30eb\u30c9\u3092\u8ffd\u52a0<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">&lt;%= form_with(model: @user, local: true) do |form| %&gt;\n  &lt;%= form.file_field :avatar %&gt;\n  &lt;%= form.submit '\u4fdd\u5b58' %&gt;\n&lt;% end %&gt;<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-15\">\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u3067\u30d1\u30e9\u30e1\u30fc\u30bf\u3092\u53d7\u3051\u53d6\u308a<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">def create\n  @user = User.new(user_params)\n  if @user.save\n    redirect_to @user, notice: '\u30e6\u30fc\u30b6\u30fc\u304c\u4f5c\u6210\u3055\u308c\u307e\u3057\u305f\u3002'\n  else\n    render :new\n  end\nend\n\nprivate\n\ndef user_params\n  params.require(:user).permit(:name, :email, :avatar)\nend<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-16\">\u30e2\u30c7\u30eb\u306b\u30a2\u30c3\u30d7\u30ed\u30fc\u30c0\u30fc\u3092\u95a2\u9023\u4ed8\u3051<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class User &lt; ApplicationRecord\n  mount_uploader :avatar, AvatarUploader\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u5b9f\u88c5\u306b\u3088\u308a\u3001\u30e6\u30fc\u30b6\u30fc\u306f\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u50cf\u306a\u3069\u306e\u5358\u4e00\u30d5\u30a1\u30a4\u30eb\u3092\u7c21\u5358\u306b\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-17\">\u8907\u6570\u30d5\u30a1\u30a4\u30eb\u306e\u540c\u6642\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u5bfe\u5fdc<\/h3>\n\n\n\n<p>\u8907\u6570\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u540c\u6642\u306b\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3059\u308b\u5834\u5408\u3001\u4ee5\u4e0b\u306e\u65b9\u6cd5\u3067\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-18\">\u30d3\u30e5\u30fc\u3067\u8907\u6570\u30d5\u30a1\u30a4\u30eb\u306e\u9078\u629e\u3092\u53ef\u80fd\u306b\u3059\u308b<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">&lt;%= form_with(model: @product, local: true) do |form| %&gt;\n  &lt;%= form.file_field :images, multiple: true %&gt;\n  &lt;%= form.submit '\u4fdd\u5b58' %&gt;\n&lt;% end %&gt;<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-19\">\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u3067\u8907\u6570\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u51e6\u7406<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">def create\n  @product = Product.new(product_params)\n  if @product.save\n    params[:images]&amp;.each { |image| @product.images.create(file: image) }\n    redirect_to @product, notice: '\u88fd\u54c1\u304c\u4f5c\u6210\u3055\u308c\u307e\u3057\u305f\u3002'\n  else\n    render :new\n  end\nend\n\nprivate\n\ndef product_params\n  params.require(:product).permit(:name, :description)\nend<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-20\">\u30e2\u30c7\u30eb\u306b\u8907\u6570\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u95a2\u9023\u4ed8\u3051\u308b<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class Product &lt; ApplicationRecord\n  has_many :images\nend\n\nclass Image &lt; ApplicationRecord\n  belongs_to :product\n  mount_uploader :file, ImageUploader\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u65b9\u6cd5\u306b\u3088\u308a\u3001\u4f8b\u3048\u3070\u88fd\u54c1\u30ab\u30bf\u30ed\u30b0\u30b5\u30a4\u30c8\u3067\u8907\u6570\u306e\u5546\u54c1\u753b\u50cf\u3092\u4e00\u5ea6\u306b\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-21\">\u30c9\u30e9\u30c3\u30b0\uff06\u30c9\u30ed\u30c3\u30d7\u306b\u3088\u308b\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9UX\u306e\u5411\u4e0a<\/h3>\n\n\n\n<p>\u30c9\u30e9\u30c3\u30b0\uff06\u30c9\u30ed\u30c3\u30d7\u306b\u3088\u308b\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306f\u3001\u30e6\u30fc\u30b6\u30fc\u4f53\u9a13\u3092\u5927\u5e45\u306b\u5411\u4e0a\u3055\u305b\u307e\u3059\u3002<br>\u4ee5\u4e0b\u306e\u624b\u9806\u3067\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-22\">JavaScript\u30e9\u30a4\u30d6\u30e9\u30ea\uff08\u4f8b\uff1aDropzone.js\uff09\u3092\u5c0e\u5165<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">&lt;script src=\"https:\/\/cdnjs.cloudflare.com\/ajax\/libs\/dropzone\/5.7.2\/min\/dropzone.min.js\"&gt;&lt;\/script&gt;\n&lt;link rel=\"stylesheet\" href=\"https:\/\/cdnjs.cloudflare.com\/ajax\/libs\/dropzone\/5.7.2\/dropzone.min.css\"&gt;<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-23\">\u30c9\u30e9\u30c3\u30b0\uff06\u30c9\u30ed\u30c3\u30d7\u30a8\u30ea\u30a2\u306e\u8a2d\u5b9a<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">&lt;%= form_with(model: @product, local: true, html: { class: 'dropzone', id: 'product-images' }) do |form| %&gt;\n  &lt;div class=\"fallback\"&gt;\n    &lt;%= form.file_field :images, multiple: true %&gt;\n  &lt;\/div&gt;\n&lt;% end %&gt;<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-24\">JavaScript\u3067Dropzone\u306e\u8a2d\u5b9a<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">Dropzone.options.productImages = {\n  paramName: \"images\",\n  maxFilesize: 2, \/\/ MB\n  acceptedFiles: \"image\/*\",\n  addRemoveLinks: true,\n  dictDefaultMessage: \"\u3053\u3053\u306b\u30d5\u30a1\u30a4\u30eb\u3092\u30c9\u30e9\u30c3\u30b0\uff06\u30c9\u30ed\u30c3\u30d7\u3057\u3066\u304f\u3060\u3055\u3044\",\n  init: function() {\n    this.on(\"success\", function(file, response) {\n      \/\/ \u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6210\u529f\u6642\u306e\u51e6\u7406\n    });\n  }\n};<\/pre>\n\n\n\n<p>\u3053\u306e\u5b9f\u88c5\u306b\u3088\u308a\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u5229\u70b9\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30e6\u30fc\u30b6\u30fc\u4f53\u9a13\u306e\u5927\u5e45\u306a\u5411\u4e0a<\/li>\n\n\n\n<li>\u8907\u6570\u30d5\u30a1\u30a4\u30eb\u306e\u52b9\u7387\u7684\u306a\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9<\/li>\n\n\n\n<li>\u30d7\u30ed\u30b0\u30ec\u30b9\u30d0\u30fc\u306b\u3088\u308b\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u72b6\u6cc1\u306e\u53ef\u8996\u5316<\/li>\n\n\n\n<li>\u30d5\u30a1\u30a4\u30eb\u306e\u8ffd\u52a0\u30fb\u524a\u9664\u304c\u5bb9\u6613<\/li>\n<\/ul>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u30c6\u30af\u30cb\u30c3\u30af\u3092\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001\u69d8\u3005\u306a\u30e6\u30fc\u30b9\u30b1\u30fc\u30b9\u306b\u5bfe\u5fdc\u3057\u305f\u67d4\u8edf\u306a\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6a5f\u80fd\u3092\u5b9f\u73fe\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#fff9e6;color:#ffb36b\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#ffb36b\"><i class=\"fas fa-pencil-alt\"><\/i><\/span><div class=\"sng-box-msg__title\">\u4f8b\u3048\u3070\u2026\uff1f<\/div><\/div><div class=\"sng-box-msg__contents\">\n<p>\u30e6\u30fc\u30b6\u30fc\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u30da\u30fc\u30b8\u3067\u306f\u5358\u4e00\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3001\u30d5\u30a9\u30c8\u30ae\u30e3\u30e9\u30ea\u30fc\u30a2\u30d7\u30ea\u3067\u306f\u8907\u6570\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3001\u305d\u3057\u3066\u5927\u5bb9\u91cf\u30d5\u30a1\u30a4\u30eb\u5171\u6709\u30b5\u30fc\u30d3\u30b9\u3067\u306f\u30c9\u30e9\u30c3\u30b0\uff06\u30c9\u30ed\u30c3\u30d7\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3092\u4f7f\u7528\u3059\u308b\u306a\u3069\u3001\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u8981\u4ef6\u306b\u5fdc\u3058\u3066\u9069\u5207\u306a\u65b9\u6cd5\u3092\u9078\u629e\u3067\u304d\u307e\u3059\u3002<\/p>\n<\/div><\/div><\/div>\n\n\n\n<p>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u305f\u753b\u50cf\u306e\u51e6\u7406\u65b9\u6cd5\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-sgb-headings sgb-heading\" id=\"i-25\"><span class=\"sgb-heading__inner sgb-heading--type1 with-icon\" style=\"background-color:transparent;border-color:transparent;font-size:1.2em\"><i class=\"fa fa-check\" style=\"color:var(--wp--preset--color--sango-main)\"><\/i><span class=\"sgb-heading__text\" style=\"color:#333\">\u753b\u50cf\u51e6\u7406\u6a5f\u80fd\u306e\u6d3b\u7528\u6cd5<\/span><\/span><\/h2>\n\n\n\n<p>CarrierWave\u306e\u5f37\u529b\u306a\u6a5f\u80fd\u306e\u4e00\u3064\u306b\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u305f\u753b\u50cf\u306e\u81ea\u52d5\u51e6\u7406\u304c\u3042\u308a\u307e\u3059\u3002<br>RMagick\u3084MiniMagick\u306a\u3069\u306e\u753b\u50cf\u51e6\u7406\u30e9\u30a4\u30d6\u30e9\u30ea\u3068\u9023\u643a\u3059\u308b\u3053\u3068\u3067\u3001\u30b5\u30e0\u30cd\u30a4\u30eb\u751f\u6210\u3001\u30ea\u30b5\u30a4\u30ba\u3001\u5f62\u5f0f\u5909\u63db\u3001\u54c1\u8cea\u8abf\u6574\u306a\u3069\u3092\u7c21\u5358\u306b\u884c\u3046\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br>\u3053\u3053\u3067\u306f\u3001\u3053\u308c\u3089\u306e\u6a5f\u80fd\u306e\u6d3b\u7528\u6cd5\u3092\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-26\">\u30b5\u30e0\u30cd\u30a4\u30eb\u751f\u6210\u306b\u3088\u308b\u8868\u793a\u306e\u6700\u9069\u5316<\/h3>\n\n\n\n<p>\u30b5\u30e0\u30cd\u30a4\u30eb\u306f\u3001\u753b\u50cf\u4e00\u89a7\u8868\u793a\u3084\u30d7\u30ec\u30d3\u30e5\u30fc\u306b\u6b20\u304b\u305b\u307e\u305b\u3093\u3002<br>CarrierWave\u3067\u306f\u3001<code>version<\/code>\u30e1\u30bd\u30c3\u30c9\u3092\u4f7f\u7528\u3057\u3066\u7c21\u5358\u306b\u30b5\u30e0\u30cd\u30a4\u30eb\u3092\u751f\u6210\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class ImageUploader &lt; CarrierWave::Uploader::Base\n  include CarrierWave::MiniMagick\n\n  version :thumb do\n    process resize_to_fit: [50, 50]\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u8a2d\u5b9a\u306b\u3088\u308a\u3001\u30aa\u30ea\u30b8\u30ca\u30eb\u753b\u50cf\u3068\u306f\u5225\u306b50\u00d750\u30d4\u30af\u30bb\u30eb\u306e\u30b5\u30e0\u30cd\u30a4\u30eb\u304c\u81ea\u52d5\u751f\u6210\u3055\u308c\u307e\u3059\u3002<br>\u4f7f\u7528\u6642\u306f\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">&lt;%= image_tag @image.file.thumb.url %&gt;<\/pre>\n\n\n\n<p>\u3053\u308c\u306b\u3088\u308a\u3001\u4e00\u89a7\u8868\u793a\u306e\u9ad8\u901f\u5316\u3084\u30e2\u30d0\u30a4\u30eb\u30c7\u30d0\u30a4\u30b9\u3067\u306e\u8868\u793a\u6700\u9069\u5316\u304c\u53ef\u80fd\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-27\">\u753b\u50cf\u30ea\u30b5\u30a4\u30ba\u3068\u5f62\u5f0f\u5909\u63db\u306e\u30c6\u30af\u30cb\u30c3\u30af<\/h3>\n\n\n\n<p>CarrierWave\u3067\u306f\u3001\u69d8\u3005\u306a\u753b\u50cf\u30ea\u30b5\u30a4\u30ba\u65b9\u6cd5\u3092\u63d0\u4f9b\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-28\"><code>resize_to_fit<\/code>: \u30a2\u30b9\u30da\u30af\u30c8\u6bd4\u3092\u7dad\u6301\u3057\u306a\u304c\u3089\u3001\u6307\u5b9a\u30b5\u30a4\u30ba\u306b\u53ce\u3081\u307e\u3059\u3002<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   process resize_to_fit: [800, 600]<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-29\"><code>resize_to_fill<\/code>: \u6307\u5b9a\u30b5\u30a4\u30ba\u306b\u3074\u3063\u305f\u308a\u5408\u308f\u305b\u3066\u5207\u308a\u629c\u304d\u307e\u3059\u3002<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   process resize_to_fill: [400, 400]<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-30\"><code>resize_and_pad<\/code>: \u6307\u5b9a\u30b5\u30a4\u30ba\u306b\u53ce\u3081\u3001\u4f59\u767d\u3092\u57cb\u3081\u307e\u3059\u3002<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   process resize_and_pad: [500, 500, background: :transparent]<\/pre>\n\n\n\n<p>\u753b\u50cf\u5f62\u5f0f\u306e\u5909\u63db\u3082\u7c21\u5358\u306b\u884c\u3048\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">process convert: 'png'<\/pre>\n\n\n\n<p>\u3053\u308c\u306b\u3088\u308a\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u305f\u753b\u50cf\u3092\u81ea\u52d5\u7684\u306bPNG\u5f62\u5f0f\u306b\u5909\u63db\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-31\">\u753b\u50cf\u306e\u54c1\u8cea\u8abf\u6574\u3068\u30d5\u30a1\u30a4\u30eb\u30b5\u30a4\u30ba\u6700\u9069\u5316<\/h3>\n\n\n\n<p>\u753b\u50cf\u306e\u54c1\u8cea\u8abf\u6574\u306f\u3001\u30d5\u30a1\u30a4\u30eb\u30b5\u30a4\u30ba\u306e\u6700\u9069\u5316\u306b\u91cd\u8981\u3067\u3059\u3002<br>JPEG\u753b\u50cf\u306e\u5834\u5408\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u54c1\u8cea\u3092\u8abf\u6574\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">process quality: 85<\/pre>\n\n\n\n<p>PNG\u753b\u50cf\u306e\u6700\u9069\u5316\u306f\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u884c\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">process :optimize<\/pre>\n\n\n\n<p>\u30d5\u30a1\u30a4\u30eb\u30b5\u30a4\u30ba\u306e\u6700\u9069\u5316\u306f\u3001\u753b\u50cf\u306e\u30ea\u30b5\u30a4\u30ba\u3068\u54c1\u8cea\u8abf\u6574\u3092\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u52b9\u679c\u7684\u306b\u884c\u3048\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">process resize_to_limit: [1920, 1080]\nprocess quality: 85<\/pre>\n\n\n\n<p>\u3053\u308c\u306b\u3088\u308a\u3001\u5927\u304d\u3059\u304e\u308b\u753b\u50cf\u3092\u9069\u5207\u306a\u30b5\u30a4\u30ba\u306b\u7e2e\u5c0f\u3057\u3001\u3055\u3089\u306b\u54c1\u8cea\u3092\u8abf\u6574\u3057\u3066\u30d5\u30a1\u30a4\u30eb\u30b5\u30a4\u30ba\u3092\u524a\u6e1b\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-block-simple sgb-box-simple sgb-box-simple--title-normal sgb-box-simple--with-border\"><div style=\"background-color:var(--wp--preset--color--sango-main);color:#FFF\" class=\"sgb-box-simple__title\">\u753b\u50cf\u51e6\u7406\u306e3\u3064\u306e\u5229\u70b9<\/div><div class=\"sgb-box-simple__body\" style=\"border-color:var(--wp--preset--color--sango-main);background-color:#FFF\">\n<ol class=\"wp-block-list\">\n<li><strong>\u30a6\u30a7\u30d6\u30b5\u30a4\u30c8\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u5411\u4e0a<\/strong>\uff1a\u6700\u9069\u5316\u3055\u308c\u305f\u753b\u50cf\u306f\u30ed\u30fc\u30c9\u6642\u9593\u3092\u77ed\u7e2e\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30b9\u30c8\u30ec\u30fc\u30b8\u4f7f\u7528\u91cf\u306e\u524a\u6e1b<\/strong>\uff1a\u30d5\u30a1\u30a4\u30eb\u30b5\u30a4\u30ba\u306e\u6700\u9069\u5316\u306b\u3088\u308a\u3001\u30b9\u30c8\u30ec\u30fc\u30b8\u30b3\u30b9\u30c8\u3092\u6291\u3048\u3089\u308c\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30e6\u30fc\u30b6\u30fc\u4f53\u9a13\u306e\u5411\u4e0a<\/strong>\uff1a\u9069\u5207\u306b\u30ea\u30b5\u30a4\u30ba\u3055\u308c\u305f\u753b\u50cf\u306f\u3001\u69d8\u3005\u306a\u30c7\u30d0\u30a4\u30b9\u3067\u898b\u3084\u3059\u304f\u8868\u793a\u3055\u308c\u307e\u3059\u3002<\/li>\n<\/ol>\n<\/div><\/div>\n\n\n\n<p>\u305f\u3060\u3057\u3001\u753b\u50cf\u51e6\u7406\u306b\u306f\u30b5\u30fc\u30d0\u30fc\u30ea\u30bd\u30fc\u30b9\u3092\u6d88\u8cbb\u3059\u308b\u305f\u3081\u3001\u5927\u91cf\u306e\u753b\u50cf\u3092\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3059\u308b\u5834\u5408\u306f\u3001\u975e\u540c\u671f\u51e6\u7406\u3092\u691c\u8a0e\u3059\u308b\u306a\u3069\u306e\u5bfe\u7b56\u304c\u5fc5\u8981\u3067\u3059\u3002<\/p>\n\n\n\n<p>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001CarrierWave\u306e\u3088\u308a\u9ad8\u5ea6\u306a\u8a2d\u5b9a\u3068\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u65b9\u6cd5\u306b\u3064\u3044\u3066\u6df1\u6398\u308a\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-sgb-headings sgb-heading\" id=\"i-32\"><span class=\"sgb-heading__inner sgb-heading--type1 with-icon\" style=\"background-color:transparent;border-color:transparent;font-size:1.2em\"><i class=\"fa fa-check\" style=\"color:var(--wp--preset--color--sango-main)\"><\/i><span class=\"sgb-heading__text\" style=\"color:#333\">\u9ad8\u5ea6\u306a\u8a2d\u5b9a\u3068\u30ab\u30b9\u30bf\u30de\u30a4\u30ba<\/span><\/span><\/h2>\n\n\n\n<p>CarrierWave\u306f\u3001\u57fa\u672c\u7684\u306a\u6a5f\u80fd\u306b\u52a0\u3048\u3066\u3001\u9ad8\u5ea6\u306a\u8a2d\u5b9a\u3084\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u304c\u53ef\u80fd\u3067\u3059\u3002<br>\u3053\u308c\u306b\u3088\u308a\u3001\u7279\u5b9a\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u8981\u4ef6\u306b\u5408\u308f\u305b\u3066\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6a5f\u80fd\u3092\u7d30\u304b\u304f\u8abf\u6574\u3067\u304d\u307e\u3059\u3002<br>\u3053\u3053\u3067\u306f\u3001\u30b9\u30c8\u30ec\u30fc\u30b8\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u306e\u9078\u629e\u3001\u30d5\u30c3\u30af\u51e6\u7406\u3001\u30ab\u30b9\u30bf\u30e0\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u306a\u3069\u306e\u9ad8\u5ea6\u306a\u8a2d\u5b9a\u65b9\u6cd5\u3092\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-33\">\u30b9\u30c8\u30ec\u30fc\u30b8\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u306e\u9078\u629e\u3068\u8a2d\u5b9a<\/h3>\n\n\n\n<p>CarrierWave\u306f\u8907\u6570\u306e\u30b9\u30c8\u30ec\u30fc\u30b8\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u3092\u30b5\u30dd\u30fc\u30c8\u3057\u3066\u3044\u307e\u3059\u3002<br>\u4e3b\u306a\u9078\u629e\u80a2\u306f\u4ee5\u4e0b\u306e\u901a\u308a\u3067\u3059\u3002<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30ed\u30fc\u30ab\u30eb\u30d5\u30a1\u30a4\u30eb\u30b7\u30b9\u30c6\u30e0\uff08\u30c7\u30d5\u30a9\u30eb\u30c8\uff09<\/li>\n\n\n\n<li>Amazon S3<\/li>\n\n\n\n<li>Google Cloud Storage<\/li>\n<\/ol>\n\n\n\n<p>\u30ed\u30fc\u30ab\u30eb\u30d5\u30a1\u30a4\u30eb\u30b7\u30b9\u30c6\u30e0\u3092\u4f7f\u7528\u3059\u308b\u5834\u5408\u306f\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u8a2d\u5b9a\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class MyUploader &lt; CarrierWave::Uploader::Base\n  storage :file\nend<\/pre>\n\n\n\n<p>\u30af\u30e9\u30a6\u30c9\u30b9\u30c8\u30ec\u30fc\u30b8\uff08\u4f8b\uff1aAmazon S3\uff09\u3092\u4f7f\u7528\u3059\u308b\u5834\u5408\u306f\u3001fog gem\u3092\u5229\u7528\u3057\u3066\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u8a2d\u5b9a\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">CarrierWave.configure do |config|\n  config.fog_credentials = {\n    provider:              'AWS',\n    aws_access_key_id:     'YOUR_ACCESS_KEY',\n    aws_secret_access_key: 'YOUR_SECRET_KEY',\n    region:                'us-east-1'\n  }\n  config.fog_directory  = 'your-bucket-name'\n  config.fog_public     = false\n  config.fog_attributes = { cache_control: \"public, max-age=#{365.days.to_i}\" }\nend\n\nclass MyUploader &lt; CarrierWave::Uploader::Base\n  storage :fog\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u8a2d\u5b9a\u306b\u3088\u308a\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u305f\u30d5\u30a1\u30a4\u30eb\u304c\u81ea\u52d5\u7684\u306bAmazon S3\u306b\u4fdd\u5b58\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-34\">\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u524d\u5f8c\u306e\u51e6\u7406\u3092\u30d5\u30c3\u30af\u3067\u5236\u5fa1<\/h3>\n\n\n\n<p>CarrierWave\u3067\u306f\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306e\u524d\u5f8c\u306b\u7279\u5b9a\u306e\u51e6\u7406\u3092\u5b9f\u884c\u3059\u308b\u305f\u3081\u306e\u30d5\u30c3\u30af\u3092\u63d0\u4f9b\u3057\u3066\u3044\u307e\u3059\u3002<br>\u3053\u308c\u3089\u306e\u30d5\u30c3\u30af\u3092\u4f7f\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u30d5\u30a1\u30a4\u30eb\u51e6\u7406\u306e\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u3092\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u4f8b\u3048\u3070\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u524d\u306b\u30ad\u30e3\u30c3\u30b7\u30e5ID\u3092\u8a18\u61b6\u3057\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u5f8c\u306b\u53e4\u3044\u4e00\u6642\u30d5\u30a1\u30a4\u30eb\u3092\u524a\u9664\u3059\u308b\u51e6\u7406\u3092\u8ffd\u52a0\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class MyUploader &lt; CarrierWave::Uploader::Base\n  before :store, :remember_cache_id\n  after :store, :delete_old_tmp_file\n\n  def remember_cache_id(new_file)\n    @cache_id_was = cache_id\n  end\n\n  def delete_old_tmp_file(new_file)\n    if @cache_id_was.present? &amp;&amp; @cache_id_was != cache_id\n      if @cache_id_was =~ \/\\A[\\d]{8}\\-[\\d]{4}\\-[\\d]+\\-[\\d]{4}\\z\/\n        FileUtils.rm_rf(File.join(root, cache_dir, @cache_id_was))\n      end\n    end\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u30d5\u30c3\u30af\u3092\u4f7f\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u30d5\u30a1\u30a4\u30eb\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u30d7\u30ed\u30bb\u30b9\u3092\u3088\u308a\u7d30\u304b\u304f\u5236\u5fa1\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-35\">\u72ec\u81ea\u306e\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u30eb\u30fc\u30eb\u306e\u5b9f\u88c5\u65b9\u6cd5<\/h3>\n\n\n\n<p>CarrierWave\u3067\u306f\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u308b\u30d5\u30a1\u30a4\u30eb\u306b\u5bfe\u3057\u3066\u72ec\u81ea\u306e\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u30eb\u30fc\u30eb\u3092\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<br>\u4ee5\u4e0b\u306f\u3044\u304f\u3064\u304b\u306e\u4e00\u822c\u7684\u306a\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u4f8b\u3067\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-36\">\u30d5\u30a1\u30a4\u30eb\u30b5\u30a4\u30ba\u306e\u5236\u9650<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">def size_range\n  1.byte..5.megabytes\nend<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-37\">\u8a31\u53ef\u3059\u308b\u30d5\u30a1\u30a4\u30eb\u5f62\u5f0f\u306e\u6307\u5b9a<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">def extension_allowlist\n  %w(jpg jpeg gif png)\nend<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-38\">\u753b\u50cf\u30b5\u30a4\u30ba\u306e\u30c1\u30a7\u30c3\u30af<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">def check_dimensions\n  if file &amp;&amp; model.avatar?\n    if file.width != 100 || file.height != 100\n      errors.add(:file, \"must be 100x100px\")\n    end\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u3092\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u308b\u30d5\u30a1\u30a4\u30eb\u304c\u7279\u5b9a\u306e\u6761\u4ef6\u3092\u6e80\u305f\u3057\u3066\u3044\u308b\u3053\u3068\u3092\u78ba\u8a8d\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-39\">\u305d\u306e\u4ed6\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u4f8b<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-40\">\u30d5\u30a1\u30a4\u30eb\u540d\u306e\u751f\u6210<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">def filename\n  \"#{secure_token}.#{file.extension}\" if original_filename.present?\nend\n\nprotected\ndef secure_token\n  var = :\"@#{mounted_as}_secure_token\"\n  model.instance_variable_get(var) or model.instance_variable_set(var, SecureRandom.uuid)\nend<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-41\">\u4fdd\u5b58\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">def store_dir\n  \"uploads\/#{model.class.to_s.underscore}\/#{mounted_as}\/#{model.id}\"\nend<\/pre>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u9ad8\u5ea6\u306a\u8a2d\u5b9a\u3068\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u306b\u3088\u308a\u3001CarrierWave\u3092\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u7279\u5b9a\u306e\u8981\u4ef6\u306b\u5408\u308f\u305b\u3066\u8abf\u6574\u3067\u304d\u307e\u3059\u3002<br>\u305f\u3060\u3057\u3001\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u3092\u884c\u3046\u969b\u306f\u4ee5\u4e0b\u306e\u70b9\u306b\u6ce8\u610f\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-block-simple sgb-box-simple sgb-box-simple--title-normal sgb-box-simple--with-border\"><div style=\"background-color:var(--wp--preset--color--sango-main);color:#FFF\" class=\"sgb-box-simple__title\"><code>carrierwave<\/code>\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u6642\u306e3\u3064\u306e\u6ce8\u610f\u70b9<\/div><div class=\"sgb-box-simple__body\" style=\"border-color:var(--wp--preset--color--sango-main);background-color:#FFF\">\n<ul class=\"wp-block-list\">\n<li><strong>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3<\/strong>\uff1a\u7279\u306b\u30d5\u30a1\u30a4\u30eb\u540d\u306e\u751f\u6210\u3084\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u3067\u306f\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30ea\u30b9\u30af\u3092\u8003\u616e\u3059\u308b\u3002<\/li>\n\n\n\n<li><strong>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9<\/strong>\uff1a\u8907\u96d1\u306a\u51e6\u7406\u3092\u8ffd\u52a0\u3059\u308b\u5834\u5408\u306f\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u901f\u5ea6\u3078\u306e\u5f71\u97ff\u3092\u8003\u616e\u3059\u308b\u3002<\/li>\n\n\n\n<li><strong>\u30e1\u30f3\u30c6\u30ca\u30f3\u30b9\u6027<\/strong>\uff1a\u904e\u5ea6\u306b\u8907\u96d1\u306a\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u306f\u3001\u5c06\u6765\u306e\u30e1\u30f3\u30c6\u30ca\u30f3\u30b9\u3092\u96e3\u3057\u304f\u3059\u308b\u53ef\u80fd\u6027\u304c\u3042\u308b\u3002<\/li>\n<\/ul>\n<\/div><\/div>\n\n\n\n<p>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001CarrierWave\u3092\u4f7f\u7528\u3059\u308b\u969b\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-sgb-headings sgb-heading\" id=\"i-42\"><span class=\"sgb-heading__inner sgb-heading--type1 with-icon\" style=\"background-color:transparent;border-color:transparent;font-size:1.2em\"><i class=\"fa fa-check\" style=\"color:var(--wp--preset--color--sango-main)\"><\/i><span class=\"sgb-heading__text\" style=\"color:#333\">\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/span><\/span><\/h2>\n\n\n\n<p>\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6a5f\u80fd\u306f\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30ea\u30b9\u30af\u3092\u4f34\u3046\u53ef\u80fd\u6027\u304c\u3042\u308a\u307e\u3059\u3002<br>CarrierWave\u3092\u4f7f\u7528\u3059\u308b\u969b\u306f\u3001\u9069\u5207\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3092\u8b1b\u3058\u308b\u3053\u3068\u304c\u975e\u5e38\u306b\u91cd\u8981\u3067\u3059\u3002<br>\u3053\u3053\u3067\u306f\u3001\u4e3b\u8981\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-43\">\u8a31\u53ef\u3059\u308b\u30d5\u30a1\u30a4\u30eb\u5f62\u5f0f\u306e\u5236\u9650\u8a2d\u5b9a<\/h3>\n\n\n\n<p>\u7279\u5b9a\u306e\u30d5\u30a1\u30a4\u30eb\u5f62\u5f0f\u306e\u307f\u3092\u8a31\u53ef\u3059\u308b\u3053\u3068\u3067\u3001\u60aa\u610f\u306e\u3042\u308b\u30d5\u30a1\u30a4\u30eb\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3092\u9632\u3050\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br>CarrierWave\u3067\u306f\u3001<code>extension_allowlist<\/code>\u30e1\u30bd\u30c3\u30c9\u3092\u4f7f\u7528\u3057\u3066\u3053\u308c\u3092\u5b9f\u73fe\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class MyUploader &lt; CarrierWave::Uploader::Base\n  def extension_allowlist\n    %w(jpg jpeg gif png)\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u8a2d\u5b9a\u306b\u3088\u308a\u3001\u6307\u5b9a\u3055\u308c\u305f\u62e1\u5f35\u5b50\u3092\u6301\u3064\u30d5\u30a1\u30a4\u30eb\u306e\u307f\u304c\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3092\u8a31\u53ef\u3055\u308c\u307e\u3059\u3002<br>\u3053\u308c\u306f\u3001\u5b9f\u884c\u53ef\u80fd\u30d5\u30a1\u30a4\u30eb\u3084\u4e0d\u9069\u5207\u306a\u30d5\u30a1\u30a4\u30eb\u30bf\u30a4\u30d7\u306b\u3088\u308b\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30ea\u30b9\u30af\u3092\u5927\u5e45\u306b\u8efd\u6e1b\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-44\">\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u30b5\u30a4\u30ba\u306e\u5236\u9650\u3068DDoS\u5bfe\u7b56<\/h3>\n\n\n\n<p>\u30d5\u30a1\u30a4\u30eb\u30b5\u30a4\u30ba\u3092\u5236\u9650\u3059\u308b\u3053\u3068\u3067\u3001\u30b5\u30fc\u30d0\u30fc\u30ea\u30bd\u30fc\u30b9\u306e\u904e\u5270\u306a\u6d88\u8cbb\u3084\u6f5c\u5728\u7684\u306aDDoS\u653b\u6483\u3092\u9632\u3050\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br><code>size_range<\/code>\u30e1\u30bd\u30c3\u30c9\u3092\u4f7f\u7528\u3057\u3066\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u308b\u30d5\u30a1\u30a4\u30eb\u306e\u30b5\u30a4\u30ba\u7bc4\u56f2\u3092\u6307\u5b9a\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class MyUploader &lt; CarrierWave::Uploader::Base\n  def size_range\n    1.byte..5.megabytes\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u8a2d\u5b9a\u306b\u3088\u308a\u30015MB\u4ee5\u4e0b\u306e\u30d5\u30a1\u30a4\u30eb\u306e\u307f\u304c\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3092\u8a31\u53ef\u3055\u308c\u307e\u3059\u3002<br>\u5927\u5bb9\u91cf\u30d5\u30a1\u30a4\u30eb\u306e\u9023\u7d9a\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306b\u3088\u308b\u30b5\u30fc\u30d0\u30fc\u8ca0\u8377\u3092\u9632\u3050\u3053\u3068\u304c\u3067\u304d\u3001DDoS\u653b\u6483\u306e\u30ea\u30b9\u30af\u3092\u8efd\u6e1b\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-45\">\u30d5\u30a1\u30a4\u30eb\u540d\u306e\u30b5\u30cb\u30bf\u30a4\u30ba\u306b\u3088\u308b\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5f37\u5316<\/h3>\n\n\n\n<p>\u30e6\u30fc\u30b6\u30fc\u304c\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3057\u305f\u30d5\u30a1\u30a4\u30eb\u540d\u306b\u306f\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30ea\u30b9\u30af\u304c\u542b\u307e\u308c\u3066\u3044\u308b\u53ef\u80fd\u6027\u304c\u3042\u308a\u307e\u3059\u3002<br>\u30d5\u30a1\u30a4\u30eb\u540d\u3092\u30b5\u30cb\u30bf\u30a4\u30ba\u3059\u308b\u3053\u3068\u3067\u3001\u3053\u308c\u3089\u306e\u30ea\u30b9\u30af\u3092\u8efd\u6e1b\u3067\u304d\u307e\u3059\u3002<br>\u4ee5\u4e0b\u306f<code>sanitize_filename<\/code>\u30e1\u30bd\u30c3\u30c9\u3092\u30aa\u30fc\u30d0\u30fc\u30e9\u30a4\u30c9\u3059\u308b\u4f8b\u3067\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class MyUploader &lt; CarrierWave::Uploader::Base\n  def sanitize_filename(filename)\n    filename.strip.tap do |name|\n      name.sub!(\/\\A.*(\\\\|\\\/)\/, '')\n      name.gsub!(\/[^0-9A-Za-z.\\-]\/, '_')\n    end\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u5b9f\u88c5\u306b\u3088\u308a\u3001\u30d5\u30a1\u30a4\u30eb\u540d\u304b\u3089\u6f5c\u5728\u7684\u306b\u5371\u967a\u306a\u6587\u5b57\u3084\u69cb\u9020\u304c\u53d6\u308a\u9664\u304b\u308c\u3001\u3088\u308a\u5b89\u5168\u306a\u30d5\u30a1\u30a4\u30eb\u540d\u304c\u751f\u6210\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-46\">\u305d\u306e\u4ed6\u306e\u91cd\u8981\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-47\">CSRF\u5bfe\u7b56<\/h4>\n\n\n\n<p>Rails\u7d44\u307f\u8fbc\u307f\u306eCSRF\u4fdd\u8b77\u6a5f\u80fd\u3092\u5229\u7528\u3057\u3001\u30d5\u30a9\u30fc\u30e0\u306b<code>authenticity_token<\/code>\u3092\u542b\u3081\u308b\u3053\u3068\u3067\u3001\u30af\u30ed\u30b9\u30b5\u30a4\u30c8\u30ea\u30af\u30a8\u30b9\u30c8\u30d5\u30a9\u30fc\u30b8\u30a7\u30ea\u653b\u6483\u3092\u9632\u304e\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-48\">\u6a29\u9650\u7ba1\u7406<\/h4>\n\n\n\n<p>\u30e6\u30fc\u30b6\u30fc\u306e\u6a29\u9650\u306b\u5fdc\u3058\u3066\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6a5f\u80fd\u3078\u306e\u30a2\u30af\u30bb\u30b9\u3092\u5236\u9650\u3057\u307e\u3059\u3002<br>\u4f8b\u3048\u3070\u3001Devise\u3068\u7d44\u307f\u5408\u308f\u305b\u3066\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   before_action :authenticate_user!\n   before_action :check_upload_permission, only: [:create, :update]\n\n   def check_upload_permission\n     unless current_user.can_upload?\n       flash[:error] = \"\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6a29\u9650\u304c\u3042\u308a\u307e\u305b\u3093\"\n       redirect_to root_path\n     end\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-49\">\u30b9\u30c8\u30ec\u30fc\u30b8\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3<\/h4>\n\n\n\n<p>\u30af\u30e9\u30a6\u30c9\u30b9\u30c8\u30ec\u30fc\u30b8\u3092\u4f7f\u7528\u3059\u308b\u5834\u5408\u3001\u9069\u5207\u306a\u30a2\u30af\u30bb\u30b9\u6a29\u9650\u3092\u8a2d\u5b9a\u3057\u3001\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u30d5\u30a1\u30a4\u30eb\u306e\u6697\u53f7\u5316\u3092\u884c\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-50\">CarrierWave\u4f7f\u7528\u6642\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/h3>\n\n\n\n<div class=\"wp-block-sgb-block-simple sgb-box-simple sgb-box-simple--title-normal sgb-box-simple--with-border\"><div style=\"background-color:var(--wp--preset--color--sango-main);color:#FFF\" class=\"sgb-box-simple__title\">CarrierWave\u4f7f\u7528\u6642\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u30105\u30b9\u30c6\u30c3\u30d7\u3011<\/div><div class=\"sgb-box-simple__body\" style=\"border-color:var(--wp--preset--color--sango-main);background-color:#FFF\">\n<ol class=\"wp-block-list\">\n<li><strong>\u30d0\u30c3\u30af\u30b0\u30e9\u30a6\u30f3\u30c9\u51e6\u7406\u306e\u5229\u7528<\/strong>\uff1a\u5927\u304d\u306a\u30d5\u30a1\u30a4\u30eb\u3084\u591a\u6570\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3059\u308b\u969b\u306f\u3001ActiveJob\u306a\u3069\u3092\u4f7f\u7528\u3057\u3066\u30d0\u30c3\u30af\u30b0\u30e9\u30a6\u30f3\u30c9\u3067\u51e6\u7406\u3092\u884c\u3044\u3001\u30e6\u30fc\u30b6\u30fc\u4f53\u9a13\u3092\u5411\u4e0a\u3055\u305b\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u4e00\u6642\u30d5\u30a1\u30a4\u30eb\u306e\u9069\u5207\u306a\u7ba1\u7406<\/strong>\uff1a\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u30d7\u30ed\u30bb\u30b9\u4e2d\u306e\u4e00\u6642\u30d5\u30a1\u30a4\u30eb\u3092\u5b9a\u671f\u7684\u306b\u524a\u9664\u3057\u3001\u30c7\u30a3\u30b9\u30af\u5bb9\u91cf\u306e\u7121\u99c4\u9063\u3044\u3092\u9632\u304e\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u306e\u5b9f\u88c5<\/strong>\uff1a\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u5931\u6557\u6642\u306b\u9069\u5207\u306a\u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u8868\u793a\u3057\u3001\u30e6\u30fc\u30b6\u30fc\u306b\u554f\u984c\u3092\u660e\u78ba\u306b\u4f1d\u3048\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30ed\u30b0\u306e\u9069\u5207\u306a\u7ba1\u7406<\/strong>\uff1a\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306b\u95a2\u3059\u308b\u30ed\u30b0\u3092\u9069\u5207\u306b\u8a18\u9332\u3057\u3001\u554f\u984c\u304c\u767a\u751f\u3057\u305f\u969b\u306e\u8abf\u67fb\u3092\u5bb9\u6613\u306b\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u5b9a\u671f\u7684\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u76e3\u67fb<\/strong>\uff1a\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u305f\u30d5\u30a1\u30a4\u30eb\u3084\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6a5f\u80fd\u81ea\u4f53\u3092\u5b9a\u671f\u7684\u306b\u76e3\u67fb\u3057\u3001\u6f5c\u5728\u7684\u306a\u8106\u5f31\u6027\u3092\u65e9\u671f\u306b\u767a\u898b\u3057\u3066\u5bfe\u51e6\u3057\u307e\u3059\u3002<\/li>\n<\/ol>\n<\/div><\/div>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u3092\u9069\u5207\u306b\u5b9f\u88c5\u3059\u308b\u3053\u3068\u3067\u3001CarrierWave\u3092\u4f7f\u7528\u3057\u305f\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6a5f\u80fd\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3068\u4fe1\u983c\u6027\u3092\u5927\u5e45\u306b\u5411\u4e0a\u3055\u305b\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br>\u5e38\u306b\u6700\u65b0\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u60c5\u5831\u306b\u6ce8\u610f\u3092\u6255\u3044\u3001\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u5bfe\u7b56\u3092\u66f4\u65b0\u3059\u308b\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002<\/p>\n\n\n\n<p>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001CarrierWave\u3092\u4f7f\u7528\u3059\u308b\u969b\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u30c6\u30af\u30cb\u30c3\u30af\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-sgb-headings sgb-heading\" id=\"i-51\"><span class=\"sgb-heading__inner sgb-heading--type1 with-icon\" style=\"background-color:transparent;border-color:transparent;font-size:1.2em\"><i class=\"fa fa-check\" style=\"color:var(--wp--preset--color--sango-main)\"><\/i><span class=\"sgb-heading__text\" style=\"color:#333\">\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u30c6\u30af\u30cb\u30c3\u30af<\/span><\/span><\/h2>\n\n\n\n<p>CarrierWave\u3092\u4f7f\u7528\u3059\u308b\u969b\u3001\u7279\u306b\u5927\u91cf\u306e\u30d5\u30a1\u30a4\u30eb\u3084\u5927\u5bb9\u91cf\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u6271\u3046\u5834\u5408\u3001\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u6700\u9069\u5316\u306f\u975e\u5e38\u306b\u91cd\u8981\u3067\u3059\u3002<br>\u3053\u3053\u3067\u306f\u3001CarrierWave\u3092\u4f7f\u7528\u3057\u305f\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3092\u5411\u4e0a\u3055\u305b\u308b\u305f\u3081\u306e\u4e3b\u8981\u306a\u30c6\u30af\u30cb\u30c3\u30af\u306b\u3064\u3044\u3066\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-52\">\u975e\u540c\u671f\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306b\u3088\u308b\u5fdc\u7b54\u6027\u5411\u4e0a<\/h3>\n\n\n\n<p>\u5927\u5bb9\u91cf\u30d5\u30a1\u30a4\u30eb\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3084\u591a\u6570\u306e\u30d5\u30a1\u30a4\u30eb\u306e\u540c\u6642\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306f\u3001\u30e6\u30fc\u30b6\u30fc\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5fdc\u7b54\u6027\u3092\u4f4e\u4e0b\u3055\u305b\u308b\u53ef\u80fd\u6027\u304c\u3042\u308a\u307e\u3059\u3002\u3053\u308c\u3092\u89e3\u6c7a\u3059\u308b\u305f\u3081\u306b\u3001\u975e\u540c\u671f\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3092\u5b9f\u88c5\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>ActiveJob\u3068Sidekiq\u3092\u4f7f\u7528\u3057\u305f\u975e\u540c\u671f\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306e\u4f8b<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># app\/jobs\/file_upload_job.rb\nclass FileUploadJob &lt; ApplicationJob\n  queue_as :default\n\n  def perform(user_id, file_path)\n    user = User.find(user_id)\n    user.avatar.attach(io: File.open(file_path), filename: 'avatar.jpg')\n  end\nend\n\n# app\/controllers\/avatars_controller.rb\nclass AvatarsController &lt; ApplicationController\n  def create\n    file = params[:file]\n    current_user.update(avatar_processing: true)\n    FileUploadJob.perform_later(current_user.id, file.path)\n    redirect_to user_path(current_user), notice: '\u30a2\u30d0\u30bf\u30fc\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3092\u958b\u59cb\u3057\u307e\u3057\u305f\u3002'\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u65b9\u6cd5\u306b\u3088\u308a\u3001\u30d5\u30a1\u30a4\u30eb\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3068\u51e6\u7406\u3092\u30d0\u30c3\u30af\u30b0\u30e9\u30a6\u30f3\u30c9\u3067\u884c\u3044\u3001\u30e6\u30fc\u30b6\u30fc\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5fdc\u7b54\u6027\u3092\u4fdd\u3061\u306a\u304c\u3089\u3001\u5927\u5bb9\u91cf\u30d5\u30a1\u30a4\u30eb\u306e\u51e6\u7406\u304c\u53ef\u80fd\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-53\">CDN\u3092\u6d3b\u7528\u3057\u305f\u30b3\u30f3\u30c6\u30f3\u30c4\u914d\u4fe1\u306e\u9ad8\u901f\u5316<\/h3>\n\n\n\n<p>Content Delivery Network (CDN) \u3092\u4f7f\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u305f\u30d5\u30a1\u30a4\u30eb\u306e\u914d\u4fe1\u3092\u9ad8\u901f\u5316\u3067\u304d\u307e\u3059\u3002<br>\u7279\u306b\u30b0\u30ed\u30fc\u30d0\u30eb\u306b\u5c55\u958b\u3059\u308b\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u5834\u5408\u3001CDN\u306e\u5229\u7528\u306f\u975e\u5e38\u306b\u52b9\u679c\u7684\u3067\u3059\u3002<\/p>\n\n\n\n<p>AWS\u306eS3\u3068CloudFront\u3092\u4f7f\u7528\u3059\u308b\u8a2d\u5b9a\u4f8b<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">CarrierWave.configure do |config|\n  config.fog_credentials = {\n    provider: 'AWS',\n    aws_access_key_id: ENV['AWS_ACCESS_KEY_ID'],\n    aws_secret_access_key: ENV['AWS_SECRET_ACCESS_KEY'],\n    region: 'us-east-1'\n  }\n  config.fog_directory = 'your-bucket-name'\n  config.asset_host = 'https:\/\/your-cloudfront-domain.com'\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u8a2d\u5b9a\u306b\u3088\u308a\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u305f\u30d5\u30a1\u30a4\u30eb\u304cS3\u306b\u4fdd\u5b58\u3055\u308c\u3001CloudFront\u7d4c\u7531\u3067\u914d\u4fe1\u3055\u308c\u307e\u3059\u3002<br>\u3053\u308c\u306b\u3088\u308a\u3001\u4e16\u754c\u4e2d\u306e\u30e6\u30fc\u30b6\u30fc\u306b\u5bfe\u3057\u3066\u9ad8\u901f\u306a\u30a2\u30af\u30bb\u30b9\u304c\u53ef\u80fd\u306b\u306a\u308a\u3001\u540c\u6642\u306b\u30aa\u30ea\u30b8\u30f3\u30b5\u30fc\u30d0\u30fc\u306e\u8ca0\u8377\u3082\u8efd\u6e1b\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-54\">\u30ad\u30e3\u30c3\u30b7\u30e5\u6226\u7565\u306b\u3088\u308b\u30ed\u30fc\u30c9\u6642\u9593\u306e\u77ed\u7e2e<\/h3>\n\n\n\n<p>\u9069\u5207\u306a\u30ad\u30e3\u30c3\u30b7\u30e5\u6226\u7565\u3092\u5b9f\u88c5\u3059\u308b\u3053\u3068\u3067\u3001\u30ea\u30d4\u30fc\u30c8\u30a2\u30af\u30bb\u30b9\u6642\u306e\u30ed\u30fc\u30c9\u6642\u9593\u3092\u5927\u5e45\u306b\u77ed\u7e2e\u3067\u304d\u307e\u3059\u3002<br>CarrierWave\u3067\u306f\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u305f\u30d5\u30a1\u30a4\u30eb\u306b\u30ad\u30e3\u30c3\u30b7\u30e5\u30d8\u30c3\u30c0\u30fc\u3092\u8a2d\u5b9a\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">CarrierWave.configure do |config|\n  config.fog_attributes = { 'Cache-Control' =&gt; 'max-age=315576000' }\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u8a2d\u5b9a\u306b\u3088\u308a\u3001\u30d6\u30e9\u30a6\u30b6\u306f\u4e00\u5ea6\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u3057\u305f\u30d5\u30a1\u30a4\u30eb\u3092\u9577\u671f\u9593\u30ad\u30e3\u30c3\u30b7\u30e5\u3059\u308b\u305f\u3081\u3001\u30ea\u30d4\u30fc\u30c8\u30a2\u30af\u30bb\u30b9\u6642\u306e\u9ad8\u901f\u5316\u3068\u5e2f\u57df\u5e45\u4f7f\u7528\u91cf\u306e\u524a\u6e1b\u304c\u53ef\u80fd\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-55\">\u305d\u306e\u4ed6\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u30c6\u30af\u30cb\u30c3\u30af<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-56\">\u753b\u50cf\u306e\u6700\u9069\u5316<\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6642\u306b\u753b\u50cf\u3092\u5727\u7e2e\u3059\u308b<\/li>\n\n\n\n<li>WebP\u5f62\u5f0f\u306a\u3069\u3001\u3088\u308a\u52b9\u7387\u7684\u306a\u753b\u50cf\u30d5\u30a9\u30fc\u30de\u30c3\u30c8\u3092\u4f7f\u7528\u3059\u308b<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-57\">\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306e\u6700\u9069\u5316<\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u305f\u30d5\u30a1\u30a4\u30eb\u306b\u95a2\u9023\u3059\u308b\u30ab\u30e9\u30e0\u306b\u30a4\u30f3\u30c7\u30c3\u30af\u30b9\u3092\u9069\u5207\u306b\u8a2d\u5b9a\u3059\u308b<\/li>\n\n\n\n<li>N+1\u30af\u30a8\u30ea\u554f\u984c\u3092\u89e3\u6c7a\u3057\u3001\u5fc5\u8981\u306a\u30c7\u30fc\u30bf\u3092\u52b9\u7387\u7684\u306b\u53d6\u5f97\u3059\u308b<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-58\">\u30da\u30fc\u30b8\u30cd\u30fc\u30b7\u30e7\u30f3\u306e\u5b9f\u88c5<\/h4>\n\n\n\n<p>\u591a\u6570\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u8868\u793a\u3059\u308b\u969b\u306f\u3001\u30da\u30fc\u30b8\u30cd\u30fc\u30b7\u30e7\u30f3\u3092\u5b9f\u88c5\u3057\u3066\u3001\u4e00\u5ea6\u306b\u8868\u793a\u3059\u308b\u30d5\u30a1\u30a4\u30eb\u6570\u3092\u5236\u9650\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># \u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u30fc\ndef index\n  @images = Image.page(params[:page]).per(20)\nend\n\n# \u30d3\u30e5\u30fc\uff08Kaminari\u3092\u4f7f\u7528\u3057\u305f\u4f8b\uff09\n&lt;%= paginate @images %&gt;<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-59\">\u9045\u5ef6\u8aad\u307f\u8fbc\u307f\u306e\u5b9f\u88c5<\/h4>\n\n\n\n<p>\u753b\u50cf\u306e\u9045\u5ef6\u8aad\u307f\u8fbc\u307f\uff08Lazy Loading\uff09\u3092\u5b9f\u88c5\u3059\u308b\u3053\u3068\u3067\u3001\u521d\u671f\u30da\u30fc\u30b8\u30ed\u30fc\u30c9\u6642\u9593\u3092\u77ed\u7e2e\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">&lt;img data-src=\"&lt;%= image.file.url %&gt;\" class=\"lazyload\" \/&gt;<\/pre>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ LazyLoad\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u4f7f\u7528\ndocument.addEventListener(\"DOMContentLoaded\", function() {\n  var lazyloadImages = document.querySelectorAll(\"img.lazyload\");    \n  var lazyloadThrottleTimeout;\n\n  function lazyload () {\n    if(lazyloadThrottleTimeout) {\n      clearTimeout(lazyloadThrottleTimeout);\n    }    \n\n    lazyloadThrottleTimeout = setTimeout(function() {\n      var scrollTop = window.pageYOffset;\n      lazyloadImages.forEach(function(img) {\n        if(img.offsetTop &lt; (window.innerHeight + scrollTop)) {\n          img.src = img.dataset.src;\n          img.classList.remove('lazyload');\n        }\n      });\n      if(lazyloadImages.length == 0) { \n        document.removeEventListener(\"scroll\", lazyload);\n        window.removeEventListener(\"resize\", lazyload);\n        window.removeEventListener(\"orientationChange\", lazyload);\n      }\n    }, 20);\n  }\n\n  document.addEventListener(\"scroll\", lazyload);\n  window.addEventListener(\"resize\", lazyload);\n  window.addEventListener(\"orientationChange\", lazyload);\n});<\/pre>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u30c6\u30af\u30cb\u30c3\u30af\u3092\u9069\u5207\u306b\u5b9f\u88c5\u3059\u308b\u3053\u3068\u3067\u3001CarrierWave\u3092\u4f7f\u7528\u3057\u305f\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u5fdc\u7b54\u6027\u3068\u5168\u4f53\u7684\u306a\u30e6\u30fc\u30b6\u30fc\u4f53\u9a13\u3092\u5927\u5e45\u306b\u5411\u4e0a\u3055\u305b\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u6700\u9069\u5316\u306f\u3001\u5358\u306b\u30da\u30fc\u30b8\u306e\u8aad\u307f\u8fbc\u307f\u901f\u5ea6\u3092\u5411\u4e0a\u3055\u305b\u308b\u3060\u3051\u3067\u306a\u304f\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u91cd\u8981\u306a\u5229\u70b9\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-block-simple sgb-box-simple sgb-box-simple--title-normal sgb-box-simple--with-border\"><div style=\"background-color:var(--wp--preset--color--sango-main);color:#FFF\" class=\"sgb-box-simple__title\">carrierwave\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u306b\u3088\u308b4\u3064\u306e\u5229\u70b9<\/div><div class=\"sgb-box-simple__body\" style=\"border-color:var(--wp--preset--color--sango-main);background-color:#FFF\">\n<ol class=\"wp-block-list\">\n<li><strong>\u30e6\u30fc\u30b6\u30fc\u6e80\u8db3\u5ea6\u306e\u5411\u4e0a<\/strong>\uff1a\u9ad8\u901f\u3067\u5fdc\u7b54\u6027\u306e\u826f\u3044\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306f\u3001\u30e6\u30fc\u30b6\u30fc\u306e\u6e80\u8db3\u5ea6\u3092\u9ad8\u3081\u3001\u30ea\u30c6\u30f3\u30b7\u30e7\u30f3\u7387\u306e\u5411\u4e0a\u306b\u3064\u306a\u304c\u308a\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>SEO\u306e\u6539\u5584<\/strong>\uff1a\u30da\u30fc\u30b8\u8aad\u307f\u8fbc\u307f\u901f\u5ea6\u306fGoogle\u306e\u30e9\u30f3\u30ad\u30f3\u30b0\u8981\u56e0\u306e\u4e00\u3064\u3067\u3042\u308a\u3001\u6700\u9069\u5316\u306b\u3088\u3063\u3066Search Engine Results Page\uff08SERP\uff09\u3067\u306e\u30e9\u30f3\u30ad\u30f3\u30b0\u304c\u5411\u4e0a\u3059\u308b\u53ef\u80fd\u6027\u304c\u3042\u308a\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30b5\u30fc\u30d0\u30fc\u30ea\u30bd\u30fc\u30b9\u306e\u52b9\u7387\u7684\u306a\u4f7f\u7528<\/strong>\uff1a\u6700\u9069\u5316\u3055\u308c\u305f\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306f\u3001\u30b5\u30fc\u30d0\u30fc\u30ea\u30bd\u30fc\u30b9\u3092\u52b9\u7387\u7684\u306b\u4f7f\u7528\u3057\u3001\u540c\u3058\u30cf\u30fc\u30c9\u30a6\u30a7\u30a2\u3067\u3088\u308a\u591a\u304f\u306e\u30e6\u30fc\u30b6\u30fc\u3092\u30b5\u30dd\u30fc\u30c8\u3067\u304d\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30e2\u30d0\u30a4\u30eb\u30e6\u30fc\u30b6\u30fc\u3078\u306e\u5bfe\u5fdc<\/strong>\uff1a\u7279\u306b\u901a\u4fe1\u901f\u5ea6\u304c\u5236\u9650\u3055\u308c\u308b\u53ef\u80fd\u6027\u306e\u3042\u308b\u30e2\u30d0\u30a4\u30eb\u30e6\u30fc\u30b6\u30fc\u306b\u3068\u3063\u3066\u3001\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u6700\u9069\u5316\u306f\u91cd\u8981\u3067\u3059\u3002<\/li>\n<\/ol>\n<\/div><\/div>\n\n\n\n<p>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u306f\u7d99\u7d9a\u7684\u306a\u30d7\u30ed\u30bb\u30b9\u3067\u3042\u308a\u3001\u5b9a\u671f\u7684\u306b\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3092\u6e2c\u5b9a\u3057\u3001\u65b0\u3057\u3044\u6700\u9069\u5316\u6280\u8853\u3092\u9069\u7528\u3057\u3066\u3044\u304f\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002<\/p>\n\n\n\n<p>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001CarrierWave\u3068\u4ed6\u306eGem\u306e\u9023\u643a\u6d3b\u7528\u6cd5\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-sgb-headings sgb-heading\" id=\"i-60\"><span class=\"sgb-heading__inner sgb-heading--type1 with-icon\" style=\"background-color:transparent;border-color:transparent;font-size:1.2em\"><i class=\"fa fa-check\" style=\"color:var(--wp--preset--color--sango-main)\"><\/i><span class=\"sgb-heading__text\" style=\"color:#333\">CarrierWave\u3068\u4ed6\u306eGem\u306e\u9023\u643a\u6d3b\u7528\u6cd5<\/span><\/span><\/h2>\n\n\n\n<p>CarrierWave\u306f\u5358\u72ec\u3067\u3082\u5f37\u529b\u306a\u6a5f\u80fd\u3092\u63d0\u4f9b\u3057\u307e\u3059\u304c\u3001\u4ed6\u306eGem\u3068\u9023\u643a\u3059\u308b\u3053\u3068\u3067\u3055\u3089\u306b\u67d4\u8edf\u3067\u9ad8\u5ea6\u306a\u30d5\u30a1\u30a4\u30eb\u51e6\u7406\u304c\u53ef\u80fd\u306b\u306a\u308a\u307e\u3059\u3002<br>\u3053\u3053\u3067\u306f\u3001CarrierWave\u3068\u76f8\u6027\u306e\u826f\u3044\u4e3b\u8981\u306aGem\u306e\u9023\u643a\u6d3b\u7528\u6cd5\u306b\u3064\u3044\u3066\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-61\">Fog Gem\u3092\u4f7f\u7528\u3057\u305f\u30af\u30e9\u30a6\u30c9\u30b9\u30c8\u30ec\u30fc\u30b8\u3068\u306e\u7d71\u5408<\/h3>\n\n\n\n<p>Fog Gem\u306f\u3001\u69d8\u3005\u306a\u30af\u30e9\u30a6\u30c9\u30b5\u30fc\u30d3\u30b9\u30d7\u30ed\u30d0\u30a4\u30c0\u30fc\u3068\u306e\u7d71\u5408\u3092\u53ef\u80fd\u306b\u3059\u308b\u30e9\u30a4\u30d6\u30e9\u30ea\u3067\u3059\u3002<br>CarrierWave\u3068Fog\u3092\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001Amazon S3\u3084Google Cloud Storage\u306a\u3069\u3001\u8907\u6570\u306e\u30af\u30e9\u30a6\u30c9\u30b9\u30c8\u30ec\u30fc\u30b8\u3092\u7c21\u5358\u306b\u5229\u7528\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u8a2d\u5b9a\u4f8b\uff08Amazon S3\u306e\u5834\u5408\uff09<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">CarrierWave.configure do |config|\n  config.fog_credentials = {\n    provider: 'AWS',\n    aws_access_key_id: ENV['AWS_ACCESS_KEY_ID'],\n    aws_secret_access_key: ENV['AWS_SECRET_ACCESS_KEY'],\n    region: 'us-east-1'\n  }\n  config.fog_directory = 'your-bucket-name'\n  config.storage = :fog\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u8a2d\u5b9a\u306b\u3088\u308a\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u305f\u30d5\u30a1\u30a4\u30eb\u304c\u81ea\u52d5\u7684\u306bAmazon S3\u306b\u4fdd\u5b58\u3055\u308c\u307e\u3059\u3002<br>Fog\u3092\u4f7f\u7528\u3059\u308b\u5229\u70b9\u306f\u3001\u8907\u6570\u306e\u30af\u30e9\u30a6\u30c9\u30d7\u30ed\u30d0\u30a4\u30c0\u30fc\u306b\u5bfe\u5fdc\u3067\u304d\u308b\u3053\u3068\u3068\u3001\u67d4\u8edf\u306a\u8a2d\u5b9a\u304c\u53ef\u80fd\u306a\u3053\u3068\u3067\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-62\">MiniMagick\u306b\u3088\u308b\u9ad8\u5ea6\u306a\u753b\u50cf\u52a0\u5de5\u306e\u5b9f\u73fe<\/h3>\n\n\n\n<p>MiniMagick\u306f\u3001ImageMagick\u3092\u4f7f\u7528\u3057\u305f\u8efd\u91cf\u306a\u753b\u50cf\u51e6\u7406\u30e9\u30a4\u30d6\u30e9\u30ea\u3067\u3059\u3002<br>CarrierWave\u3068MiniMagick\u3092\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6642\u306b\u9ad8\u5ea6\u306a\u753b\u50cf\u52a0\u5de5\u3092\u884c\u3046\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u4ee5\u4e0b\u3001\u4f7f\u7528\u4f8b<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class ImageUploader &lt; CarrierWave::Uploader::Base\n  include CarrierWave::MiniMagick\n\n  process resize_to_fit: [800, 800]\n\n  version :thumb do\n    process resize_to_fill: [200,200]\n  end\n\n  version :medium do\n    process resize_to_fit: [400, 400]\n  end\n\n  def extension_allowlist\n    %w(jpg jpeg gif png)\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u4f8b\u3067\u306f\u3001\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u305f\u753b\u50cf\u3092\u6700\u5927800\u00d7800\u30d4\u30af\u30bb\u30eb\u306b\u30ea\u30b5\u30a4\u30ba\u3057\u3001\u3055\u3089\u306b200\u00d7200\u30d4\u30af\u30bb\u30eb\u306e\u30b5\u30e0\u30cd\u30a4\u30eb\u3068400\u00d7400\u30d4\u30af\u30bb\u30eb\u306e\u4e2d\u9593\u30b5\u30a4\u30ba\u306e\u753b\u50cf\u3092\u751f\u6210\u3057\u3066\u3044\u307e\u3059\u3002<br>MiniMagick\u306f\u8efd\u91cf\u3067\u9ad8\u901f\u3001\u304b\u3064\u30e1\u30e2\u30ea\u4f7f\u7528\u91cf\u304c\u5c11\u306a\u3044\u305f\u3081\u3001\u5927\u91cf\u306e\u753b\u50cf\u51e6\u7406\u306b\u9069\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-63\">CarrierWave Direct\u3067S3\u3078\u306e\u76f4\u63a5\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9<\/h3>\n\n\n\n<p>CarrierWave Direct\u306f\u3001\u30d6\u30e9\u30a6\u30b6\u304b\u3089Amazon S3\u306b\u76f4\u63a5\u30d5\u30a1\u30a4\u30eb\u3092\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3059\u308b\u305f\u3081\u306e\u62e1\u5f35\u6a5f\u80fd\u3067\u3059\u3002<br>\u3053\u308c\u306b\u3088\u308a\u3001\u30b5\u30fc\u30d0\u30fc\u306e\u8ca0\u8377\u3092\u8efd\u6e1b\u3057\u3001\u5927\u5bb9\u91cf\u30d5\u30a1\u30a4\u30eb\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3092\u52b9\u7387\u7684\u306b\u884c\u3046\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u4ee5\u4e0b\u3001\u8a2d\u5b9a\u4f8b<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">class AvatarUploader &lt; CarrierWave::Uploader::Base\n  include CarrierWaveDirect::Uploader\nend<\/pre>\n\n\n\n<p>\u4ee5\u4e0b\u3001\u30d3\u30e5\u30fc\u3067\u306e\u4f7f\u7528\u4f8b<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">&lt;%= direct_upload_form_for @uploader do |f| %&gt;\n  &lt;%= f.file_field :avatar %&gt;\n  &lt;%= f.submit '\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9' %&gt;\n&lt;% end %&gt;<\/pre>\n\n\n\n<p>CarrierWave Direct\u3092\u4f7f\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u5927\u5bb9\u91cf\u30d5\u30a1\u30a4\u30eb\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3084\u30b5\u30fc\u30d0\u30fc\u30ea\u30bd\u30fc\u30b9\u306e\u52b9\u7387\u7684\u306a\u5229\u7528\u304c\u53ef\u80fd\u306b\u306a\u308a\u307e\u3059\u3002<br>\u7279\u306b\u3001\u30e6\u30fc\u30b6\u30fc\u304c\u30d3\u30c7\u30aa\u3084\u9ad8\u89e3\u50cf\u5ea6\u753b\u50cf\u3092\u983b\u7e41\u306b\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3059\u308b\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306b\u9069\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-64\">\u305d\u306e\u4ed6\u306e\u9023\u643a\u4f8b<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-65\">ActiveStorage\u3068\u306e\u9023\u643a<\/h4>\n\n\n\n<p>Rails 5.2\u4ee5\u964d\u3067\u5c0e\u5165\u3055\u308c\u305fActiveStorage\u3078\u306e\u79fb\u884c\u3092\u691c\u8a0e\u3057\u3066\u3044\u308b\u5834\u5408\u3001CarrierWave\u304b\u3089\u306e\u6bb5\u968e\u7684\u306a\u79fb\u884c\u304c\u53ef\u80fd\u3067\u3059\u3002<br>\u4f8b\u3048\u3070\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u30e9\u30c3\u30d1\u30fc\u3092\u4f5c\u6210\u3059\u308b\u3053\u3068\u3067\u3001\u65e2\u5b58\u306eCarrierWave\u30a2\u30c3\u30d7\u30ed\u30fc\u30c0\u30fc\u3092ActiveStorage\u3067\u4f7f\u7528\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   module ActiveStorageUploader\n     extend ActiveSupport::Concern\n     include CarrierWave::MountMixin\n\n     included do\n       include ActiveModel::Validations\n     end\n\n     def store!(file)\n       record.send(:\"#{mounted_as}\").attach(io: file.to_file, filename: file.original_filename)\n     end\n\n     def retrieve_from_store!(identifier)\n       record.send(mounted_as)\n     end\n   end<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-66\">Shrine\u3068\u306e\u6bd4\u8f03<\/h4>\n\n\n\n<p>Shrine\u306f\u3001CarrierWave\u306e\u4ee3\u66ff\u3068\u3057\u3066\u4f7f\u7528\u3067\u304d\u308b\u3088\u308a\u65b0\u3057\u3044\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u30e9\u30a4\u30d6\u30e9\u30ea\u3067\u3059\u3002<br>Shrine\u306f\u3001\u3088\u308a\u67d4\u8edf\u306a\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u51e6\u7406\u3068\u9ad8\u5ea6\u306a\u30d7\u30e9\u30b0\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u3092\u63d0\u4f9b\u3057\u307e\u3059\u3002<br>CarrierWave\u304b\u3089Shrine\u3078\u306e\u79fb\u884c\u3092\u691c\u8a0e\u3059\u308b\u5834\u5408\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u5229\u70b9\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u3088\u308a\u7d30\u304b\u3044\u51e6\u7406\u306e\u5236\u5fa1<\/li>\n\n\n\n<li>\u975e\u540c\u671f\u51e6\u7406\u306e\u30cd\u30a4\u30c6\u30a3\u30d6\u30b5\u30dd\u30fc\u30c8<\/li>\n\n\n\n<li>\u30d7\u30e9\u30b0\u30a4\u30f3\u306b\u3088\u308b\u6a5f\u80fd\u62e1\u5f35\u306e\u5bb9\u6613\u3055<\/li>\n<\/ul>\n\n\n\n<p>CarrierWave\u3068\u4ed6\u306eGem\u3092\u9023\u643a\u3055\u305b\u308b\u3053\u3068\u3067\u3001\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30d5\u30a1\u30a4\u30eb\u51e6\u7406\u6a5f\u80fd\u3092\u5927\u5e45\u306b\u62e1\u5f35\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-message\"><div class=\"memo sng-shadow-0\" style=\"border-radius:0px;background-color:#fff9e6;color:#ffb36b\"><div class=\"memo_ttl dfont\"><span class=\"sng-box-msg__icon\" style=\"background:#ffb36b\"><i class=\"fas fa-pencil-alt\"><\/i><\/span><div class=\"sng-box-msg__title\">Gem\u306f\u4fbf\u5229\u3060\u3051\u3069\u2026\uff1f<\/div><\/div><div class=\"sng-box-msg__contents\">\n<p>\u65b0\u3057\u3044Gem\u3092\u5c0e\u5165\u3059\u308b\u969b\u306f\u3001\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u8981\u4ef6\u3001\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3078\u306e\u5f71\u97ff\u3001\u304a\u3088\u3073\u4fdd\u5b88\u6027\u3092\u5341\u5206\u306b\u8003\u616e\u3059\u308b\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002<br>\u9069\u5207\u306aGem\u306e\u9078\u629e\u3068\u9023\u643a\u306b\u3088\u308a\u3001\u52b9\u7387\u7684\u3067\u67d4\u8edf\u306a\u30d5\u30a1\u30a4\u30eb\u51e6\u7406\u30b7\u30b9\u30c6\u30e0\u3092\u69cb\u7bc9\u3067\u304d\u307e\u3059\u3002<\/p>\n<\/div><\/div><\/div>\n\n\n\n<p>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001CarrierWave\u3092\u4f7f\u7528\u3059\u308b\u969b\u306e\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u3068\u30c7\u30d0\u30c3\u30b0\u624b\u6cd5\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-sgb-headings sgb-heading\" id=\"i-67\"><span class=\"sgb-heading__inner sgb-heading--type1 with-icon\" style=\"background-color:transparent;border-color:transparent;font-size:1.2em\"><i class=\"fa fa-check\" style=\"color:var(--wp--preset--color--sango-main)\"><\/i><span class=\"sgb-heading__text\" style=\"color:#333\">\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u3068\u30c7\u30d0\u30c3\u30b0\u624b\u6cd5<\/span><\/span><\/h2>\n\n\n\n<p>CarrierWave\u3092\u4f7f\u7528\u3059\u308b\u969b\u306b\u906d\u9047\u3059\u308b\u53ef\u80fd\u6027\u306e\u3042\u308b\u554f\u984c\u306b\u52b9\u679c\u7684\u306b\u5bfe\u51e6\u3059\u308b\u305f\u3081\u306b\u3001\u9069\u5207\u306a\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u3068\u30c7\u30d0\u30c3\u30b0\u624b\u6cd5\u3092\u7406\u89e3\u3059\u308b\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002<br>\u3053\u3053\u3067\u306f\u3001\u3088\u304f\u3042\u308b\u30a8\u30e9\u30fc\u3068\u305d\u306e\u89e3\u6c7a\u7b56\u3001\u30ed\u30b0\u306e\u6d3b\u7528\u65b9\u6cd5\u3001\u30c6\u30b9\u30c8\u74b0\u5883\u3067\u306e\u30e2\u30c3\u30af\u5316\u306a\u3069\u3001CarrierWave\u306e\u30c7\u30d0\u30c3\u30b0\u306b\u5f79\u7acb\u3064\u624b\u6cd5\u3092\u7d39\u4ecb\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-68\">\u3088\u304f\u3042\u308b\u30a8\u30e9\u30fc\u3068\u305d\u306e\u89e3\u6c7a\u7b56<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-69\">Integrity Error<\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u539f\u56e0\uff1a\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u305f\u30d5\u30a1\u30a4\u30eb\u304c\u4e88\u671f\u305b\u305a\u5909\u66f4\u3055\u308c\u305f\u5834\u5408\u306b\u767a\u751f\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u89e3\u6c7a\u7b56\uff1a<code>config.ignore_integrity_errors = true<\/code> \u3092\u8a2d\u5b9a\u3057\u3066\u3001\u3053\u306e\u30a8\u30e9\u30fc\u3092\u7121\u8996\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002\u305f\u3060\u3057\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u4e0a\u306e\u7406\u7531\u304b\u3089\u3001\u672c\u756a\u74b0\u5883\u3067\u306f\u6ce8\u610f\u3057\u3066\u4f7f\u7528\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-70\">Processing Error<\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u539f\u56e0\uff1a\u753b\u50cf\u51e6\u7406\u4e2d\u306b\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3057\u305f\u5834\u5408\u306b\u8868\u793a\u3055\u308c\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u89e3\u6c7a\u7b56\uff1a<code>config.ignore_processing_errors = true<\/code> \u3092\u8a2d\u5b9a\u3059\u308b\u304b\u3001\u4f7f\u7528\u3057\u3066\u3044\u308b\u753b\u50cf\u51e6\u7406\u30e9\u30a4\u30d6\u30e9\u30ea\uff08MiniMagick\u306a\u3069\uff09\u304c\u6b63\u3057\u304f\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3055\u308c\u3066\u3044\u308b\u304b\u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-71\">Permissions Error<\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u539f\u56e0\uff1a\u30d5\u30a1\u30a4\u30eb\u306e\u4fdd\u5b58\u5148\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306b\u66f8\u304d\u8fbc\u307f\u6a29\u9650\u304c\u306a\u3044\u5834\u5408\u306b\u767a\u751f\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li>\u89e3\u6c7a\u7b56\uff1a\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306e\u30d1\u30fc\u30df\u30c3\u30b7\u30e7\u30f3\u8a2d\u5b9a\u3092\u78ba\u8a8d\u3057\u3001\u9069\u5207\u306a\u6a29\u9650\u3092\u4ed8\u4e0e\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-72\">\u30ed\u30b0\u3068\u30c7\u30d0\u30c3\u30b0\u51fa\u529b\u306e\u6d3b\u7528\u65b9\u6cd5<\/h3>\n\n\n\n<p>CarrierWave\u306e\u30ed\u30b0\u51fa\u529b\u3092\u6709\u52b9\u306b\u3059\u308b\u3053\u3068\u3067\u3001\u554f\u984c\u306e\u539f\u56e0\u3092\u7279\u5b9a\u3057\u3084\u3059\u304f\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">CarrierWave.configure do |config|\n  config.logger = Logger.new(STDOUT)\nend<\/pre>\n\n\n\n<p>\u3055\u3089\u306b\u3001\u30c7\u30d0\u30c3\u30b0\u30e2\u30fc\u30c9\u3092\u6709\u52b9\u306b\u3059\u308b\u3053\u3068\u3067\u3001\u3088\u308a\u8a73\u7d30\u306a\u60c5\u5831\u3092\u5f97\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">CarrierWave.configure do |config|\n  config.debug_mode = true\nend<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-73\">\u30c6\u30b9\u30c8\u74b0\u5883\u3067\u306e\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306e\u30e2\u30c3\u30af\u5316<\/h3>\n\n\n\n<p>\u30c6\u30b9\u30c8\u74b0\u5883\u3067\u306f\u3001\u5b9f\u969b\u306e\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3092\u30e2\u30c3\u30af\u5316\u3059\u308b\u3053\u3068\u3067\u3001\u30c6\u30b9\u30c8\u306e\u5b9f\u884c\u901f\u5ea6\u3092\u5411\u4e0a\u3055\u305b\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">RSpec.configure do |config|\n  config.before(:each, type: :uploader) do\n    CarrierWave::Uploader::Base.enable_processing = false\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u8a2d\u5b9a\u306b\u3088\u308a\u3001\u30c6\u30b9\u30c8\u4e2d\u306e\u753b\u50cf\u51e6\u7406\u304c\u7121\u52b9\u306b\u306a\u308a\u3001\u30c6\u30b9\u30c8\u306e\u5b9f\u884c\u304c\u9ad8\u901f\u5316\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-74\">CarrierWave\u7279\u6709\u306e\u30c7\u30d0\u30c3\u30b0\u30c6\u30af\u30cb\u30c3\u30af<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-75\">\u30a2\u30c3\u30d7\u30ed\u30fc\u30c0\u30fc\u306e\u72b6\u614b\u78ba\u8a8d<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   puts uploader.file.present?  # \u30d5\u30a1\u30a4\u30eb\u304c\u5b58\u5728\u3059\u308b\u304b\u78ba\u8a8d\n   puts uploader.url           # \u751f\u6210\u3055\u308c\u305fURL\u3092\u78ba\u8a8d<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-76\">\u30b9\u30c8\u30ec\u30fc\u30b8\u306e\u8a2d\u5b9a\u78ba\u8a8d<\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   puts uploader.class.storage  # \u73fe\u5728\u306e\u30b9\u30c8\u30ec\u30fc\u30b8\u8a2d\u5b9a\u3092\u78ba\u8a8d<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-77\">\u4e00\u822c\u7684\u306a\u30c7\u30d0\u30c3\u30b0\u30c4\u30fc\u30eb\u306e\u6d3b\u7528<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Pry: <code>binding.pry<\/code> \u3092\u4f7f\u7528\u3057\u3066\u3001\u30b3\u30fc\u30c9\u5b9f\u884c\u4e2d\u306b\u5bfe\u8a71\u7684\u306a\u30c7\u30d0\u30c3\u30b0\u30bb\u30c3\u30b7\u30e7\u30f3\u3092\u958b\u59cb\u3067\u304d\u307e\u3059\u3002<\/li>\n\n\n\n<li>Byebug: <code>debugger<\/code> \u3092\u4f7f\u7528\u3057\u3066\u3001\u30b3\u30fc\u30c9\u306e\u7279\u5b9a\u306e\u4f4d\u7f6e\u3067\u5b9f\u884c\u3092\u4e00\u6642\u505c\u6b62\u3057\u3001\u5909\u6570\u306e\u72b6\u614b\u3092\u78ba\u8a8d\u3067\u304d\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-78\">\u30b7\u30b9\u30c6\u30de\u30c6\u30a3\u30c3\u30af\u306a\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u30a2\u30d7\u30ed\u30fc\u30c1<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u8a73\u7d30\u306b\u5206\u6790\u3059\u308b<\/li>\n\n\n\n<li>\u30ed\u30b0\u3092\u78ba\u8a8d\u3057\u3001\u554f\u984c\u306e\u767a\u751f\u7b87\u6240\u3092\u7279\u5b9a\u3059\u308b<\/li>\n\n\n\n<li>\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3001\u51e6\u7406\u3001\u4fdd\u5b58\u306e\u5404\u6bb5\u968e\u3067\u6bb5\u968e\u7684\u306b\u30c7\u30d0\u30c3\u30b0\u3092\u884c\u3046<\/li>\n\n\n\n<li>\u958b\u767a\u3001\u30c6\u30b9\u30c8\u3001\u672c\u756a\u74b0\u5883\u306e\u9055\u3044\u3092\u78ba\u8a8d\u3057\u3001\u74b0\u5883\u56fa\u6709\u306e\u554f\u984c\u3092\u7279\u5b9a\u3059\u308b<\/li>\n<\/ol>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u3068\u30c7\u30d0\u30c3\u30b0\u624b\u6cd5\u3092\u6d3b\u7528\u3059\u308b\u3053\u3068\u3067\u3001CarrierWave\u306b\u95a2\u9023\u3059\u308b\u554f\u984c\u3092\u52b9\u7387\u7684\u306b\u7279\u5b9a\u3057\u3001\u89e3\u6c7a\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br>\u554f\u984c\u304c\u8907\u96d1\u306a\u5834\u5408\u306f\u3001CarrierWave\u306eGitHub\u30a4\u30b7\u30e5\u30fc\u3084\u3001Ruby\u30b3\u30df\u30e5\u30cb\u30c6\u30a3\u306e\u30d5\u30a9\u30fc\u30e9\u30e0\u3067\u652f\u63f4\u3092\u6c42\u3081\u308b\u3053\u3068\u3082\u52b9\u679c\u7684\u3067\u3059\u3002<\/p>\n\n\n\n<p>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001CarrierWave\u3092\u4f7f\u3063\u305f\u5b9f\u8df5\u7684\u306a\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u4f8b\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-sgb-headings sgb-heading\" id=\"i-79\"><span class=\"sgb-heading__inner sgb-heading--type1 with-icon\" style=\"background-color:transparent;border-color:transparent;font-size:1.2em\"><i class=\"fa fa-check\" style=\"color:var(--wp--preset--color--sango-main)\"><\/i><span class=\"sgb-heading__text\" style=\"color:#333\">CarrierWave\u3092\u4f7f\u3063\u305f\u5b9f\u8df5\u7684\u306a\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u4f8b<\/span><\/span><\/h2>\n\n\n\n<p>CarrierWave\u306e\u6a5f\u80fd\u3092\u6700\u5927\u9650\u306b\u6d3b\u7528\u3059\u308b\u305f\u3081\u3001\u5b9f\u969b\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306e\u4f7f\u7528\u4f8b\u3092\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<br>\u3053\u3053\u3067\u306f\u30013\u3064\u306e\u7570\u306a\u308b\u30bf\u30a4\u30d7\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u304a\u3051\u308bCarrierWave\u306e\u5b9f\u88c5\u65b9\u6cd5\u3092\u7d39\u4ecb\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-80\">\u30e6\u30fc\u30b6\u30fc\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u50cf\u6a5f\u80fd\u306e\u5b9f\u88c5<\/h3>\n\n\n\n<p>\u30e6\u30fc\u30b6\u30fc\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u50cf\u6a5f\u80fd\u306f\u3001\u591a\u304f\u306eWeb\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3067\u5fc5\u8981\u3068\u3055\u308c\u308b\u57fa\u672c\u7684\u306a\u6a5f\u80fd\u3067\u3059\u3002<br>CarrierWave\u3092\u4f7f\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u7c21\u5358\u306b\u3053\u306e\u6a5f\u80fd\u3092\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-block-simple sgb-box-simple sgb-box-simple--title-normal sgb-box-simple--with-border\"><div style=\"background-color:var(--wp--preset--color--sango-main);color:#FFF\" class=\"sgb-box-simple__title\">\u5b9f\u88c5\u6642\u306e3\u3064\u306e\u30dd\u30a4\u30f3\u30c8<\/div><div class=\"sgb-box-simple__body\" style=\"border-color:var(--wp--preset--color--sango-main);background-color:#FFF\">\n<ol class=\"wp-block-list\">\n<li>\u753b\u50cf\u306e\u30ea\u30b5\u30a4\u30ba\u3068\u6700\u9069\u5316<\/li>\n\n\n\n<li>\u30c7\u30d5\u30a9\u30eb\u30c8\u753b\u50cf\u306e\u8a2d\u5b9a<\/li>\n\n\n\n<li>\u753b\u50cf\u306e\u66f4\u65b0\u3068\u524a\u9664\u6a5f\u80fd<\/li>\n<\/ol>\n<\/div><\/div>\n\n\n\n<p>\u4ee5\u4e0b\u3001\u30b3\u30fc\u30c9\u4f8b<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># app\/models\/user.rb\nclass User &lt; ApplicationRecord\n  mount_uploader :avatar, AvatarUploader\nend\n\n# app\/uploaders\/avatar_uploader.rb\nclass AvatarUploader &lt; CarrierWave::Uploader::Base\n  include CarrierWave::MiniMagick\n\n  storage :file\n\n  def store_dir\n    \"uploads\/#{model.class.to_s.underscore}\/#{mounted_as}\/#{model.id}\"\n  end\n\n  # \u30ea\u30b5\u30a4\u30ba\u51e6\u7406\n  process resize_to_fit: [300, 300]\n\n  # \u30b5\u30e0\u30cd\u30a4\u30eb\u306e\u751f\u6210\n  version :thumb do\n    process resize_to_fill: [100, 100]\n  end\n\n  # \u30c7\u30d5\u30a9\u30eb\u30c8\u753b\u50cf\u306e\u8a2d\u5b9a\n  def default_url(*args)\n    \"\/images\/fallback\/\" + [version_name, \"default_avatar.png\"].compact.join('_')\n  end\n\n  # \u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u53ef\u80fd\u306a\u62e1\u5f35\u5b50\u306e\u30ea\u30b9\u30c8\n  def extension_allowlist\n    %w(jpg jpeg gif png)\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306eImplementation\u306b\u3088\u308a\u3001\u30e6\u30fc\u30b6\u30fc\u306f\u81ea\u5206\u306e\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u50cf\u3092\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3057\u3001\u30b7\u30b9\u30c6\u30e0\u306f\u81ea\u52d5\u7684\u306b\u753b\u50cf\u3092\u30ea\u30b5\u30a4\u30ba\u3057\u3066\u30b5\u30e0\u30cd\u30a4\u30eb\u3092\u751f\u6210\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-81\">\u8907\u6570\u753b\u50cf\u3092\u6271\u3046\u5546\u54c1\u30ab\u30bf\u30ed\u30b0\u30b7\u30b9\u30c6\u30e0\u306e\u69cb\u7bc9<\/h3>\n\n\n\n<p>EC\u30b5\u30a4\u30c8\u306a\u3069\u3067\u5fc5\u8981\u3068\u306a\u308b\u3001\u8907\u6570\u306e\u5546\u54c1\u753b\u50cf\u3092\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3057\u7ba1\u7406\u3059\u308b\u30b7\u30b9\u30c6\u30e0\u3082CarrierWave\u3067\u52b9\u7387\u7684\u306b\u69cb\u7bc9\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-block-simple sgb-box-simple sgb-box-simple--title-normal sgb-box-simple--with-border\"><div style=\"background-color:var(--wp--preset--color--sango-main);color:#FFF\" class=\"sgb-box-simple__title\">\u5b9f\u88c5\u6642\u306e3\u3064\u306e\u30dd\u30a4\u30f3\u30c8<\/div><div class=\"sgb-box-simple__body\" style=\"border-color:var(--wp--preset--color--sango-main);background-color:#FFF\">\n<ol class=\"wp-block-list\">\n<li>\u8907\u6570\u753b\u50cf\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3068\u7ba1\u7406<\/li>\n\n\n\n<li>\u753b\u50cf\u306e\u4e26\u3073\u66ff\u3048\u6a5f\u80fd<\/li>\n\n\n\n<li>\u30b5\u30e0\u30cd\u30a4\u30eb\u3068\u30d5\u30eb\u753b\u50cf\u306e\u751f\u6210<\/li>\n<\/ol>\n<\/div><\/div>\n\n\n\n<p>\u4ee5\u4e0b\u3001\u30b3\u30fc\u30c9\u4f8b<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># app\/models\/product.rb\nclass Product &lt; ApplicationRecord\n  mount_uploaders :images, ProductImageUploader\n  serialize :images, JSON\nend\n\n# app\/uploaders\/product_image_uploader.rb\nclass ProductImageUploader &lt; CarrierWave::Uploader::Base\n  include CarrierWave::MiniMagick\n\n  storage :file\n\n  # \u8907\u6570\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u3092\u5b9a\u7fa9\n  version :thumb do\n    process resize_to_fit: [100, 100]\n  end\n\n  version :medium do\n    process resize_to_fit: [400, 400]\n  end\n\n  # \u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u53ef\u80fd\u306a\u62e1\u5f35\u5b50\u306e\u30ea\u30b9\u30c8\n  def extension_allowlist\n    %w(jpg jpeg gif png)\n  end\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u30b7\u30b9\u30c6\u30e0\u3067\u306f\u3001\u4e00\u3064\u306e\u5546\u54c1\u306b\u8907\u6570\u306e\u753b\u50cf\u3092\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3067\u304d\u3001\u305d\u308c\u305e\u308c\u306e\u753b\u50cf\u306b\u5bfe\u3057\u3066\u7570\u306a\u308b\u30b5\u30a4\u30ba\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u304c\u81ea\u52d5\u751f\u6210\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-82\">\u5927\u5bb9\u91cf\u30d5\u30a1\u30a4\u30eb\u5171\u6709\u30b5\u30fc\u30d3\u30b9\u306e\u958b\u767a\u4e8b\u4f8b<\/h3>\n\n\n\n<p>CarrierWave\u306f\u5927\u5bb9\u91cf\u30d5\u30a1\u30a4\u30eb\u306e\u5171\u6709\u30b5\u30fc\u30d3\u30b9\u306e\u958b\u767a\u306b\u3082\u9069\u3057\u3066\u3044\u307e\u3059\u3002<br>\u30af\u30e9\u30a6\u30c9\u30b9\u30c8\u30ec\u30fc\u30b8\u3068\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001\u52b9\u7387\u7684\u306a\u30d5\u30a1\u30a4\u30eb\u5171\u6709\u30b7\u30b9\u30c6\u30e0\u3092\u69cb\u7bc9\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-block-simple sgb-box-simple sgb-box-simple--title-normal sgb-box-simple--with-border\"><div style=\"background-color:var(--wp--preset--color--sango-main);color:#FFF\" class=\"sgb-box-simple__title\">\u5b9f\u88c5\u6642\u306e3\u3064\u306e\u30dd\u30a4\u30f3\u30c8<\/div><div class=\"sgb-box-simple__body\" style=\"border-color:var(--wp--preset--color--sango-main);background-color:#FFF\">\n<ol class=\"wp-block-list\">\n<li>\u30af\u30e9\u30a6\u30c9\u30b9\u30c8\u30ec\u30fc\u30b8\u306e\u5229\u7528<\/li>\n\n\n\n<li>\u30c0\u30a4\u30ec\u30af\u30c8\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306e\u5b9f\u88c5<\/li>\n\n\n\n<li>\u30bb\u30ad\u30e5\u30a2\u306a\u5171\u6709\u30ea\u30f3\u30af\u306e\u751f\u6210<\/li>\n<\/ol>\n<\/div><\/div>\n\n\n\n<p>\u4ee5\u4e0b\u3001\u30b3\u30fc\u30c9\u4f8b<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># app\/uploaders\/file_uploader.rb\nclass FileUploader &lt; CarrierWave::Uploader::Base\n  include CarrierWaveDirect::Uploader\n\n  storage :fog\n\n  # \u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u53ef\u80fd\u306a\u30d5\u30a1\u30a4\u30eb\u30b5\u30a4\u30ba\u306e\u5236\u9650\n  def size_range\n    1.byte..10.gigabytes\n  end\n\n  # \u30bb\u30ad\u30e5\u30a2\u306aURL\u306e\u751f\u6210\n  def url(options = {})\n    if model.persisted?\n      super.url(expires_in: 1.hour.to_i)\n    else\n      super\n    end\n  end\nend\n\n# config\/initializers\/carrierwave.rb\nCarrierWave.configure do |config|\n  config.fog_credentials = {\n    provider:              'AWS',\n    aws_access_key_id:     ENV['AWS_ACCESS_KEY_ID'],\n    aws_secret_access_key: ENV['AWS_SECRET_ACCESS_KEY'],\n    region:                'us-east-1'\n  }\n  config.fog_directory  = 'your-bucket-name'\n  config.fog_public     = false\nend<\/pre>\n\n\n\n<p>\u3053\u306e\u5b9f\u88c5\u3067\u306f\u3001\u30e6\u30fc\u30b6\u30fc\u306f\u5927\u5bb9\u91cf\u30d5\u30a1\u30a4\u30eb\u3092\u76f4\u63a5\u30af\u30e9\u30a6\u30c9\u30b9\u30c8\u30ec\u30fc\u30b8\u306b\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3067\u304d\u3001\u30b7\u30b9\u30c6\u30e0\u306f\u4e00\u6642\u7684\u306a\u30a2\u30af\u30bb\u30b9\u7528URL\u3092\u751f\u6210\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-83\">\u6ce8\u610f\u70b9\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3092\u8003\u616e\u3057\u305f\u30d5\u30a1\u30a4\u30eb\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\uff1a\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u308b\u30d5\u30a1\u30a4\u30eb\u306e\u7a2e\u985e\u3084\u30b5\u30a4\u30ba\u3092\u9069\u5207\u306b\u5236\u9650\u3059\u308b\u3002<\/li>\n\n\n\n<li>\u975e\u540c\u671f\u51e6\u7406\u306b\u3088\u308b\u30e6\u30fc\u30b6\u30fc\u4f53\u9a13\u306e\u5411\u4e0a\uff1a\u5927\u5bb9\u91cf\u30d5\u30a1\u30a4\u30eb\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3084Cloudinary\u7b49\u306e\u30b5\u30fc\u30d3\u30b9\u3067\u306e\u753b\u50cf\u51e6\u7406\u3092\u975e\u540c\u671f\u3067\u884c\u3046\u3002<\/li>\n\n\n\n<li>\u9069\u5207\u306a\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u3068\u30e6\u30fc\u30b6\u30fc\u30d5\u30a3\u30fc\u30c9\u30d0\u30c3\u30af\uff1a\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u5931\u6557\u6642\u306b\u9069\u5207\u306a\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u8868\u793a\u3059\u308b\u3002<\/li>\n<\/ol>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-84\">\u30d3\u30b8\u30cd\u30b9\u30b7\u30fc\u30f3\u3067\u306e\u5fdc\u7528\u4f8b<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u4e0d\u52d5\u7523\u7269\u4ef6\u306e\u5199\u771f\u7ba1\u7406\u30b7\u30b9\u30c6\u30e0<\/strong>\uff1a\u7269\u4ef6\u3054\u3068\u306b\u8907\u6570\u306e\u9ad8\u54c1\u8cea\u5199\u771f\u3092\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3057\u7ba1\u7406\u3059\u308b\u3002<\/li>\n\n\n\n<li><strong>\u30dd\u30fc\u30c8\u30d5\u30a9\u30ea\u30aa\u5171\u6709\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0<\/strong>\uff1a\u30af\u30ea\u30a8\u30a4\u30bf\u30fc\u304c\u4f5c\u54c1\u3092\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3057\u3001\u95b2\u89a7\u8005\u3068\u5171\u6709\u3059\u308b\u3002<\/li>\n\n\n\n<li><strong>\u533b\u7642\u753b\u50cf\u7ba1\u7406\u30b7\u30b9\u30c6\u30e0<\/strong>\uff1a\u60a3\u8005\u306eX\u7dda\u753b\u50cf\u3084MRI\u753b\u50cf\u3092\u5b89\u5168\u306b\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3057\u3001\u533b\u7642\u30b9\u30bf\u30c3\u30d5\u9593\u3067\u5171\u6709\u3059\u308b\u3002<\/li>\n<\/ol>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u5b9f\u8df5\u7684\u306a\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u4f8b\u3092\u53c2\u8003\u306b\u3001CarrierWave\u3092\u6d3b\u7528\u3057\u3066\u52b9\u7387\u7684\u306a\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u30b7\u30b9\u30c6\u30e0\u3092\u69cb\u7bc9\u3057\u3066\u304f\u3060\u3055\u3044\u3002<br>\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u8981\u4ef6\u306b\u5fdc\u3058\u3066CarrierWave\u306e\u6a5f\u80fd\u3092\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u3057\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3068\u30e6\u30fc\u30b6\u30d3\u30ea\u30c6\u30a3\u306e\u30d0\u30e9\u30f3\u30b9\u3092\u53d6\u308a\u306a\u304c\u3089\u5b9f\u88c5\u3059\u308b\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>CarrierWave\u306f\u3001Ruby\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306b\u304a\u3051\u308b\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u6a5f\u80fd\u3092\u7c21\u5358\u304b\u3064\u67d4\u8edf\u306b\u5b9f\u88c5\u3067\u304d\u308b\u5f37\u529b\u306aGem\u3067\u3059\u3002\u672c\u8a18\u4e8b\u3067\u306f\u3001CarrierWave\u306e\u57fa\u672c\u7684\u306a\u4f7f\u3044\u65b9\u304b\u3089\u9ad8\u5ea6\u306a\u5b9f\u88c5\u30c6\u30af\u30cb\u30c3\u30af\u3001\u3055\u3089\u306b\u306f\u5b9f\u8df5\u7684\u306a\u30d7 &#8230; <\/p>\n","protected":false},"author":1,"featured_media":3158,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[3,65],"tags":[],"class_list":{"0":"post-68","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-ruby","8":"category-ruby-syntax"},"_links":{"self":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/68","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=68"}],"version-history":[{"count":5,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/68\/revisions"}],"predecessor-version":[{"id":84,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/68\/revisions\/84"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/media\/3158"}],"wp:attachment":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=68"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=68"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=68"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}