{"componentChunkName":"component---src-templates-post-template-js","path":"/posts/483997599X","result":{"data":{"markdownRemark":{"id":"b2fdaa9e-61b1-5ed2-a94e-4ecb678c6930","html":"<p>2021 年 9 月に発売された書籍『セキュア・バイ・デザイン』を読みました。</p>\n<p>事前になんとなく耳にしていた通り非常に素晴らしい本でしたので、感想や学びになったポイントをまとめます。</p>\n<h2 id=\"書籍『セキュア・バイ・デザイン』とは\" style=\"position:relative;\"><a href=\"#%E6%9B%B8%E7%B1%8D%E3%80%8E%E3%82%BB%E3%82%AD%E3%83%A5%E3%82%A2%E3%83%BB%E3%83%90%E3%82%A4%E3%83%BB%E3%83%87%E3%82%B6%E3%82%A4%E3%83%B3%E3%80%8F%E3%81%A8%E3%81%AF\" aria-label=\"書籍『セキュア・バイ・デザイン』とは permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>書籍『<a href=\"https://amzn.to/3ur8q7H\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">セキュア・バイ・デザイン</a>』とは</h2>\n<p><a href=\"https://www.amazon.co.jp/dp/B09F697K2V?&linkCode=li3&tag=oshimayuki0d-22&linkId=285dec79d658f13ce17acf4a645f5104&ref_=as_li_ss_il\" target=\"_blank\"><img border=\"0\" src=\"//ws-fe.amazon-adsystem.com/widgets/q?_encoding=UTF8&ASIN=B09F697K2V&Format=_SL250_&ID=AsinImage&MarketPlace=JP&ServiceVersion=20070822&WS=1&tag=oshimayuki0d-22\" ></a><img src=\"https://ir-jp.amazon-adsystem.com/e/ir?t=oshimayuki0d-22&amp;l=li3&amp;o=9&amp;a=B09F697K2V\" width=\"1\" height=\"1\" border=\"0\" alt=\"\" style=\"border:none !important; margin:0px !important;\"></p>\n<p>『セキュア・バイ・デザイン』は、タイトル通りセキュリティの観点からソフトウェア設計について解説した書籍です。</p>\n<p>しかし、いわゆるセキュリティに関心がある人に向けたものというよりも、アプリケーションエンジニアに向けた内容となっています。</p>\n<p>特に、ドメイン駆動設計 (DDD) に大きく影響を受けた内容となっており、DDD に関心がある方には是非手にとっていただきたい一冊です。</p>\n<h2 id=\"感想\" style=\"position:relative;\"><a href=\"#%E6%84%9F%E6%83%B3\" aria-label=\"感想 permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>感想</h2>\n<p>一言で言えば、DDD のメリットを理解するうえで、この上ない良著でした。</p>\n<p>サンプルコードも豊富ですし、状況設定も現実的で想像しやすい例が多く、非常に理解しやすかったです。</p>\n<p>今まで DDD やアプリケーション設計について色々な本を読み、自分でもあれこれ考え、実装したりしてきましたが、この本を読むことでさらに知見を深められたと思います。</p>\n<p>DDD などの設計手法に興味を持っている全ての方に強くおすすめできる一冊でした。</p>\n<h2 id=\"学びになったポイント\" style=\"position:relative;\"><a href=\"#%E5%AD%A6%E3%81%B3%E3%81%AB%E3%81%AA%E3%81%A3%E3%81%9F%E3%83%9D%E3%82%A4%E3%83%B3%E3%83%88\" aria-label=\"学びになったポイント permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>学びになったポイント</h2>\n<p>ここから、特に学びになったポイントを 2 つほど書いていきます。</p>\n<h3 id=\"value-object-のメリットについて\" style=\"position:relative;\"><a href=\"#value-object-%E3%81%AE%E3%83%A1%E3%83%AA%E3%83%83%E3%83%88%E3%81%AB%E3%81%A4%E3%81%84%E3%81%A6\" aria-label=\"value object のメリットについて permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>Value Object のメリットについて</h3>\n<p>この書籍では DDD における Value Object をさらに工夫した手法として、「ドメイン・プリミティブ」が紹介されます。</p>\n<p>ドメイン・プリミティブは書籍の中で終始重要な手法として扱われており、この書籍の解説を読むことで、Value Object という手法のメリットを深く理解できます。</p>\n<p>DDD の文脈で Value Object のメリットがあまりピンときていないという方は、この本を読んでみるのが一番だと思います。</p>\n<h3 id=\"セキュリティをドメインの関心事とする\" style=\"position:relative;\"><a href=\"#%E3%82%BB%E3%82%AD%E3%83%A5%E3%83%AA%E3%83%86%E3%82%A3%E3%82%92%E3%83%89%E3%83%A1%E3%82%A4%E3%83%B3%E3%81%AE%E9%96%A2%E5%BF%83%E4%BA%8B%E3%81%A8%E3%81%99%E3%82%8B\" aria-label=\"セキュリティをドメインの関心事とする permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>セキュリティをドメインの関心事とする</h3>\n<p>この書籍では、「セキュリティは、セキュリティの専門家が外部から付け加えるものではなく、アプリケーションエンジニアが常に考えるべきものとする」というような、発送の逆転的な考え方で解説されています。</p>\n<p>この言葉だけ聞くとよくある説教のようですが、それをアプリケーションエンジニアにとって興味深い手法で取り入れているのが大きな特徴です。</p>\n<p>ビジネスロジックを逆手に取った攻撃の例なども書かれており、非常に参考になりました。</p>\n<h2 id=\"難易度について\" style=\"position:relative;\"><a href=\"#%E9%9B%A3%E6%98%93%E5%BA%A6%E3%81%AB%E3%81%A4%E3%81%84%E3%81%A6\" aria-label=\"難易度について permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>難易度について</h2>\n<p>DDD に関する書籍として最も有名なのは</p>\n<ul>\n<li><a href=\"https://amzn.to/3NmhN19\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">エリック・エヴァンスのドメイン駆動設計</a></li>\n<li><a href=\"https://amzn.to/3tCgxPI\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">実践ドメイン駆動設計</a></li>\n</ul>\n<p>の 2 冊だと思います。</p>\n<p><a href=\"https://www.amazon.co.jp/dp/B00GRKD6XU?&linkCode=li1&tag=oshimayuki0d-22&linkId=10b8ec5520b0a5653b529a26e16566c7&ref_=as_li_ss_il\" target=\"_blank\"><img border=\"0\" src=\"//ws-fe.amazon-adsystem.com/widgets/q?_encoding=UTF8&ASIN=B00GRKD6XU&Format=_SL110_&ID=AsinImage&MarketPlace=JP&ServiceVersion=20070822&WS=1&tag=oshimayuki0d-22\" ></a><img src=\"https://ir-jp.amazon-adsystem.com/e/ir?t=oshimayuki0d-22&amp;l=li1&amp;o=9&amp;a=B00GRKD6XU\" width=\"1\" height=\"1\" border=\"0\" alt=\"\" style=\"border:none !important; margin:0px !important;\"></p>\n<p><a href=\"https://www.amazon.co.jp/dp/B00UX9VJGW?&linkCode=li1&tag=oshimayuki0d-22&linkId=a62dcac6a563d88696725fb184d0d3da&ref_=as_li_ss_il\" target=\"_blank\"><img border=\"0\" src=\"//ws-fe.amazon-adsystem.com/widgets/q?_encoding=UTF8&ASIN=B00UX9VJGW&Format=_SL110_&ID=AsinImage&MarketPlace=JP&ServiceVersion=20070822&WS=1&tag=oshimayuki0d-22\" ></a><img src=\"https://ir-jp.amazon-adsystem.com/e/ir?t=oshimayuki0d-22&amp;l=li1&amp;o=9&amp;a=B00UX9VJGW\" width=\"1\" height=\"1\" border=\"0\" alt=\"\" style=\"border:none !important; margin:0px !important;\"></p>\n<p>『セキュア・バイ・デザイン』は、これら 2 冊と比較するとかなり読みやすいので、まずは『セキュア・バイ・デザイン』で DDD のメリットを理解して、その後これら 2 冊に進むという流れも良いかもしれません。</p>\n<p>ただし、『セキュア・バイ・デザイン』は、DDD 全体の解説ではなく、Value Object や境界づけられたコンテキストといった、一部のプラクティスの解説になっています。</p>\n<p>DDD に関する書籍については、難易度別に <a href=\"https://www.kanzennirikaisita.com/posts/ddd-books\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">こちらの記事</a> にまとめていますので、よろしければ参考にしてください。</p>\n<h2 id=\"おわりに\" style=\"position:relative;\"><a href=\"#%E3%81%8A%E3%82%8F%E3%82%8A%E3%81%AB\" aria-label=\"おわりに permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>おわりに</h2>\n<p>最後に、印象的だったフレーズを引用させていただきます。</p>\n<blockquote>\n<p>システムについてさらに広い視野で見るようにし、システムを、ソフトウェア、本番環境、開発チームで構築されるものとして見ていきます</p>\n</blockquote>\n<p>――『セキュア・バイ・デザイン』p526</p>\n<p>システム開発というものが開発チームを作ることも含んでいることを表現した言葉として、個人的にとても印象に残りました。</p>\n<p><a href=\"https://www.amazon.co.jp/dp/B09F697K2V?&linkCode=li1&tag=oshimayuki0d-22&linkId=b09a5150775f6e989198eae866849421&ref_=as_li_ss_il\" target=\"_blank\"><img border=\"0\" src=\"//ws-fe.amazon-adsystem.com/widgets/q?_encoding=UTF8&ASIN=B09F697K2V&Format=_SL110_&ID=AsinImage&MarketPlace=JP&ServiceVersion=20070822&WS=1&tag=oshimayuki0d-22\" ></a><img src=\"https://ir-jp.amazon-adsystem.com/e/ir?t=oshimayuki0d-22&amp;l=li1&amp;o=9&amp;a=B09F697K2V\" width=\"1\" height=\"1\" border=\"0\" alt=\"\" style=\"border:none !important; margin:0px !important;\"></p>","fields":{"slug":"/posts/483997599X","tagSlugs":["/tag/ddd/","/tag/security/"],"autoRecommendPosts":["ddd-books","domain-driven-design-concepts","linux-learning-roadmap","application-architecture-books"]},"frontmatter":{"date":"2022-03-24T15:11:39.361Z","description":"2021 年 9 月に発売された書籍『セキュア・バイ・デザイン』を読みました。\n事前になんとなく耳にしていた通り非常に素晴らしい本でしたので、感想や学びになったポイントをまとめます。","tags":["ddd","security"],"title":"【感想】書籍『セキュア・バイ・デザイン』を読みました","socialImage":null,"recommendPosts":null}}},"pageContext":{"slug":"/posts/483997599X"}},"staticQueryHashes":["251939775","3942705351","401334301"]}