{"id":40012,"date":"2023-02-13T17:07:13","date_gmt":"2023-09-23T07:23:36","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82\/"},"modified":"2024-04-29T14:28:29","modified_gmt":"2024-04-29T06:28:29","slug":"%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82\/","title":{"rendered":"\u5c1d\u8bd5\u4f7f\u7528SpringBoot MVC\u5b9e\u73b0\u4e00\u4e2a\u7b80\u5355\u7684WEB\u5e94\u7528"},"content":{"rendered":"<h2>\u9996\u5148<\/h2>\n<p>\u682a\u5f0f\u4f1a\u793e\u30d4\u30fc\u30a2\u30fc\u30eb\u30aa\u30fc\uff08\u5e0c\u671b\u80fd\u5b9e\u73b0\uff01\uff09\u5c06\u8fce\u67652022\u5e74\u7684\u7b2c7\u5929\u5723\u8bde\u8282\u65e5\u5386\u3002<br \/>\n\u5728\u524d\u4e00\u5929\uff0c\u7531\u4e8e[AWS]SAM \u652f\u6301 TypeScript\uff0c\u82b1\u4e865\u5206\u949f\u5c31\u53ef\u4ee5\u521b\u5efa\u4e00\u4e2a API\u3002<\/p>\n<p>\u7531\u4e8e\u4e4b\u524d\u5df2\u7ecf\u5b8c\u6210\u4e86Spring Boot + RemoteContainer\u7684\u73af\u5883\u914d\u7f6e\uff0c\u5e76\u6210\u529f\u663e\u793a\u4e86HelloWorld\uff0c\u56e0\u6b64\u63a5\u4e0b\u6765\u5c06\u5229\u7528SpringMVC\u7684\u529f\u80fd\u6765\u521b\u5efa\u4e00\u4e2a\u7b80\u5355\u7684Web\u5e94\u7528\u7a0b\u5e8f\u3002<\/p>\n<h2>\u6784\u5efa.gradle<\/h2>\n<p>\u5728 build.gradle \u6587\u4ef6\u7684 dependencies \u4e2d\u5b9a\u4e49 Thymeleaf \u7b49\u3002<br \/>\n\u4e5f\u53ef\u4ee5\u4f7f\u7528 spring initializr \u8fdb\u884c\u8bbe\u7f6e\uff0c\u6ca1\u6709\u95ee\u9898\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">dependencies<\/span> <span class=\"o\">{<\/span>\r\n\t<span class=\"n\">implementation<\/span> <span class=\"s1\">'org.springframework.boot:spring-boot-starter-thymeleaf'<\/span>\r\n\t<span class=\"n\">implementation<\/span> <span class=\"s1\">'org.springframework.boot:spring-boot-starter-web'<\/span>\r\n\t<span class=\"n\">developmentOnly<\/span> <span class=\"s1\">'org.springframework.boot:spring-boot-devtools'<\/span>\r\n\t<span class=\"n\">testImplementation<\/span> <span class=\"s1\">'org.springframework.boot:spring-boot-starter-test'<\/span>\r\n\t<span class=\"n\">compileOnly<\/span> <span class=\"s1\">'org.projectlombok:lombok'<\/span>\r\n\t<span class=\"n\">annotationProcessor<\/span> <span class=\"s1\">'org.projectlombok:lombok'<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<div>\n<div class=\"post-table\">spring boot Dependencies\u8aac\u660eThymeleaf\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u30a8\u30f3\u30b8\u30f3Spring Webweb\u8868\u793a\u306b\u5fc5\u8981Spring Boot DevToolsjava\u306e\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u304c\u5909\u66f4\u3055\u308c\u305f\u969b\u306bspring boot \u3092\u81ea\u52d5\u3067\u518d\u8d77\u52d5\u3059\u308b\u305f\u3081\u306e\u6a5f\u80fdlombok\u30b3\u30f3\u30b9\u30c8\u30e9\u30af\u30bf\u3001\u30b2\u30c3\u30bf\u30fc\u3001\u30bb\u30c3\u30bf\u30fc\u3092\u81ea\u52d5\u3067\u4f5c\u308b\u30e9\u30a4\u30d6\u30e9\u30ea<\/div>\n<\/div>\n<h2>\u9996\u9875\u663e\u793a<\/h2>\n<p>\u5728templates\u6587\u4ef6\u5939\u4e0b\u521b\u5efaindex.html\u6587\u4ef6<br \/>\n\u5728html\u6807\u7b7e\u4e2d\uff0c\u9884\u5148\u5b9a\u4e49Thymeleaf\u7684\u6a21\u5f0f\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"cp\">&lt;!DOCTYPE html&gt;<\/span>\r\n<span class=\"nt\">&lt;html<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">\"en\"<\/span>  <span class=\"na\">xmlns:th=<\/span><span class=\"s\">\"http:\/\/www.thymeleaf.org\"<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;head&gt;<\/span>\r\n    <span class=\"nt\">&lt;meta<\/span> <span class=\"na\">charset=<\/span><span class=\"s\">\"UTF-8\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;meta<\/span> <span class=\"na\">http-equiv=<\/span><span class=\"s\">\"X-UA-Compatible\"<\/span> <span class=\"na\">content=<\/span><span class=\"s\">\"IE=edge\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;meta<\/span> <span class=\"na\">name=<\/span><span class=\"s\">\"viewport\"<\/span> <span class=\"na\">content=<\/span><span class=\"s\">\"width=device-width, initial-scale=1.0\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;title&gt;<\/span>\u30c8\u30c3\u30d7\u30da\u30fc\u30b8<span class=\"nt\">&lt;\/title&gt;<\/span>\r\n<span class=\"nt\">&lt;\/head&gt;<\/span>\r\n<span class=\"nt\">&lt;body&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>Advent Calendar 2022<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n    <span class=\"nt\">&lt;ul&gt;<\/span>\r\n        <span class=\"nt\">&lt;li&gt;<\/span>\r\n            <span class=\"c\">&lt;!-- \"@{\/issues}\" @ \u306fthymeleaf\u3067\u30ea\u30f3\u30af\u3092\u8868\u3059\u8a18\u6cd5 --&gt;<\/span>\r\n            <span class=\"c\">&lt;!-- springboot \u8d77\u52d5\u305b\u305a\u3068\u3082html\u3092\u78ba\u8a8d\u51fa\u6765\u308b\u3002\u30bf\u30a4\u30e0\u30ea\u30fc\u30d5\u631f\u307e\u306a\u3044\u30ca\u30c1\u30e5\u30e9\u30eb\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8 --&gt;<\/span>\r\n            <span class=\"nt\">&lt;a<\/span> <span class=\"na\">href=<\/span><span class=\"s\">\".\/articles\/article_list.html\"<\/span> <span class=\"na\">th:href=<\/span><span class=\"s\">\"@{\/articles}\"<\/span><span class=\"nt\">&gt;<\/span>\u8a18\u4e8b\u4e00\u89a7<span class=\"nt\">&lt;\/a&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/li&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/ul&gt;<\/span>\r\n<span class=\"nt\">&lt;\/body&gt;<\/span>\r\n<span class=\"nt\">&lt;\/html&gt;<\/span>\r\n<\/code><\/pre>\n<p>\u521b\u5efaIndexController\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kn\">package<\/span> <span class=\"nn\">com.example.its.web<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.springframework.stereotype.Controller<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.springframework.web.bind.annotation.GetMapping<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"nd\">@Controller<\/span>\r\n<span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">IndexController<\/span> <span class=\"o\">{<\/span>\r\n  \r\n  <span class=\"c1\">\/\/ GET \/<\/span>\r\n  <span class=\"nd\">@GetMapping<\/span><span class=\"o\">(<\/span><span class=\"s\">\"\/\"<\/span><span class=\"o\">)<\/span>\r\n  <span class=\"kd\">public<\/span> <span class=\"nc\">String<\/span> <span class=\"nf\">index<\/span><span class=\"o\">()<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"c1\">\/\/ \u524d\u306e\u30d1\u30b9\u306e\u62e1\u5f35\u5b50\u306fSpringMVC\u304c\u88dc\u5b8c\u3057\u3066\u304f\u308c\u308b\u306e\u3067\u66f8\u304b\u306a\u304f\u3066\u3088\u3044<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"s\">\"index\"<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"o\">}<\/span>\r\n\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3dd637434c4406c88f9d\/12-0.png\" alt=\"image.png\" \/><\/div>\n<h2>\u4f7f\u7528MVC\u529f\u80fd<\/h2>\n<p>\u6211\u5728\u9996\u9875\u7684HTML\u4e2d\u5199\u4e86\u4e00\u4e2a\u94fe\u63a5\uff0c\u53ef\u4ee5\u70b9\u51fb\u8fdb\u5165\u6587\u7ae0\u5217\u8868\u9875\u9762\uff0c\u6240\u4ee5\u9700\u8981\u521b\u5efa\u4e00\u4e2a\u8df3\u8f6c\u5230\u8be5\u9875\u9762\u7684\u9875\u9762\u3002<\/p>\n<h3>\u5b9e\u4f53<\/h3>\n<pre class=\"post-pre\"><code><span class=\"kn\">package<\/span> <span class=\"nn\">com.example.its.domain.articles<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">lombok.AllArgsConstructor<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">lombok.Data<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"c1\">\/\/\u30af\u30e9\u30b9\u306e\u5168\u3066\u306e\u30d5\u30a3\u30fc\u30eb\u30c9\u3092\u5f15\u6570\u306b\u3068\u308b\u3002<\/span>\r\n<span class=\"nd\">@AllArgsConstructor<\/span>\r\n<span class=\"nd\">@Data<\/span>\r\n<span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">ArticleEntity<\/span> <span class=\"o\">{<\/span>\r\n  <span class=\"kd\">private<\/span> <span class=\"kt\">long<\/span> <span class=\"n\">id<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"kd\">private<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">title<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"kd\">private<\/span> <span class=\"nc\">String<\/span> <span class=\"n\">impressions<\/span><span class=\"o\">;<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<h3>\u670d\u52a1<\/h3>\n<pre class=\"post-pre\"><code><span class=\"kn\">package<\/span> <span class=\"nn\">com.example.its.domain.articles<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">java.util.List<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.springframework.stereotype.Service<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"nd\">@Service<\/span>\r\n<span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">ArticleService<\/span> <span class=\"o\">{<\/span>\r\n  \r\n  <span class=\"kd\">public<\/span> <span class=\"nc\">List<\/span><span class=\"o\">&lt;<\/span><span class=\"nc\">ArticleEntity<\/span><span class=\"o\">&gt;<\/span> <span class=\"nf\">findAll<\/span><span class=\"o\">(){<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"nc\">List<\/span><span class=\"o\">.<\/span><span class=\"na\">of<\/span><span class=\"o\">(<\/span>\r\n      <span class=\"k\">new<\/span> <span class=\"nf\">ArticleEntity<\/span><span class=\"o\">(<\/span><span class=\"mi\">1<\/span><span class=\"o\">,<\/span><span class=\"s\">\"Angular \u30d5\u30a9\u30fc\u30e0\u30dc\u30bf\u30f3\u306e\u7121\u52b9\u306b\u3064\u3044\u3066\"<\/span><span class=\"o\">,<\/span><span class=\"s\">\"very good\"<\/span><span class=\"o\">),<\/span>\r\n      <span class=\"k\">new<\/span> <span class=\"nf\">ArticleEntity<\/span><span class=\"o\">(<\/span><span class=\"mi\">2<\/span><span class=\"o\">,<\/span><span class=\"s\">\"Winget\u3067\u7c21\u5358\uff01\u958b\u767aPC\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\uff08Windows\uff09\"<\/span><span class=\"o\">,<\/span><span class=\"s\">\"very good\"<\/span><span class=\"o\">),<\/span>\r\n      <span class=\"k\">new<\/span> <span class=\"nf\">ArticleEntity<\/span><span class=\"o\">(<\/span><span class=\"mi\">3<\/span><span class=\"o\">,<\/span><span class=\"s\">\"DirectML\u3067\u8a66\u3059\u3001\u975eNVIDIA\u7cfbGPU\u3067\u6a5f\u68b0\u5b66\u7fd2\"<\/span><span class=\"o\">,<\/span><span class=\"s\">\"very good\"<\/span><span class=\"o\">),<\/span>\r\n      <span class=\"k\">new<\/span> <span class=\"nf\">ArticleEntity<\/span><span class=\"o\">(<\/span><span class=\"mi\">4<\/span><span class=\"o\">,<\/span><span class=\"s\">\"Winget\u3067\u7c21\u5358\uff01\u958b\u767aPC\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\uff08Windows\uff09\"<\/span><span class=\"o\">,<\/span><span class=\"s\">\"very good\"<\/span><span class=\"o\">),<\/span>\r\n      <span class=\"k\">new<\/span> <span class=\"nf\">ArticleEntity<\/span><span class=\"o\">(<\/span><span class=\"mi\">5<\/span><span class=\"o\">,<\/span><span class=\"s\">\"DirectML\u3067Stable Diffusion\u3092\u52d5\u304b\u3057\u3066\u307f\u308b\"<\/span><span class=\"o\">,<\/span><span class=\"s\">\"very good\"<\/span><span class=\"o\">),<\/span>\r\n      <span class=\"k\">new<\/span> <span class=\"nf\">ArticleEntity<\/span><span class=\"o\">(<\/span><span class=\"mi\">6<\/span><span class=\"o\">,<\/span><span class=\"s\">\"Google\u30ab\u30ec\u30f3\u30c0\u30fc\u306e\u5f53\u65e5\u4e88\u5b9a\u3092Slack\u306b\u901a\u77e5\u3059\u308b\"<\/span><span class=\"o\">,<\/span><span class=\"s\">\"very good\"<\/span><span class=\"o\">),<\/span>\r\n      <span class=\"k\">new<\/span> <span class=\"nf\">ArticleEntity<\/span><span class=\"o\">(<\/span><span class=\"mi\">7<\/span><span class=\"o\">,<\/span><span class=\"s\">\"[AWS]SAM\u3067TypeScript\u304c\u30b5\u30dd\u30fc\u30c8\u3055\u308c\u305f\u306e\u30675\u5206\u3067API\u3092\u4f5c\u6210\u3059\u308b\"<\/span><span class=\"o\">,<\/span><span class=\"s\">\"very good\"<\/span><span class=\"o\">)<\/span>\r\n    <span class=\"o\">);<\/span>\r\n  <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<h3>\u63a7\u5236\u5668<\/h3>\n<pre class=\"post-pre\"><code><span class=\"kn\">package<\/span> <span class=\"nn\">com.example.its.web.article<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.springframework.stereotype.Controller<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.springframework.ui.Model<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">org.springframework.web.bind.annotation.GetMapping<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">com.example.its.domain.articles.ArticleService<\/span><span class=\"o\">;<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">lombok.RequiredArgsConstructor<\/span><span class=\"o\">;<\/span>\r\n\r\n<span class=\"nd\">@Controller<\/span>\r\n<span class=\"nd\">@RequiredArgsConstructor<\/span>\r\n\r\n<span class=\"kd\">public<\/span> <span class=\"kd\">class<\/span> <span class=\"nc\">ArticleController<\/span> <span class=\"o\">{<\/span>\r\n  <span class=\"c1\">\/\/ GET \/issue<\/span>\r\n  \r\n  <span class=\"kd\">private<\/span> <span class=\"kd\">final<\/span> <span class=\"nc\">ArticleService<\/span> <span class=\"n\">articleService<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"cm\">\/**\r\n   * \r\n   * @param model\r\n   * @return \r\n   *\/<\/span>\r\n  <span class=\"nd\">@GetMapping<\/span><span class=\"o\">(<\/span><span class=\"s\">\"\/articles\"<\/span><span class=\"o\">)<\/span>\r\n  <span class=\"kd\">public<\/span> <span class=\"nc\">String<\/span> <span class=\"nf\">showList<\/span><span class=\"o\">(<\/span><span class=\"nc\">Model<\/span> <span class=\"n\">model<\/span><span class=\"o\">){<\/span>\r\n    <span class=\"n\">model<\/span><span class=\"o\">.<\/span><span class=\"na\">addAttribute<\/span><span class=\"o\">(<\/span><span class=\"s\">\"articleList\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">articleService<\/span><span class=\"o\">.<\/span><span class=\"na\">findAll<\/span><span class=\"o\">());<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"s\">\"articles\/article_list\"<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<h3>\u6a21\u677f<\/h3>\n<pre class=\"post-pre\"><code><span class=\"cp\">&lt;!DOCTYPE html&gt;<\/span>\r\n<span class=\"nt\">&lt;html<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">\"en\"<\/span> <span class=\"na\">xmlns:th=<\/span><span class=\"s\">\"http:\/\/www.thymeleaf.org\"<\/span><span class=\"nt\">&gt;<\/span>\r\n<span class=\"nt\">&lt;head&gt;<\/span>\r\n    <span class=\"nt\">&lt;meta<\/span> <span class=\"na\">charset=<\/span><span class=\"s\">\"UTF-8\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;meta<\/span> <span class=\"na\">http-equiv=<\/span><span class=\"s\">\"X-UA-Compatible\"<\/span> <span class=\"na\">content=<\/span><span class=\"s\">\"IE=edge\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;meta<\/span> <span class=\"na\">name=<\/span><span class=\"s\">\"viewport\"<\/span> <span class=\"na\">content=<\/span><span class=\"s\">\"width=device-width, initial-scale=1.0\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;title&gt;<\/span>\u8a18\u4e8b\u4e00\u89a7<span class=\"nt\">&lt;\/title&gt;<\/span>\r\n<span class=\"nt\">&lt;\/head&gt;<\/span>\r\n<span class=\"nt\">&lt;body&gt;<\/span>\r\n    <span class=\"nt\">&lt;h1&gt;<\/span>\u8a18\u4e8b\u4e00\u89a7<span class=\"nt\">&lt;\/h1&gt;<\/span>\r\n    <span class=\"nt\">&lt;a<\/span> <span class=\"na\">href=<\/span><span class=\"s\">\"..\/index.html\"<\/span> <span class=\"na\">th:href=<\/span><span class=\"s\">\"@{\/}\"<\/span><span class=\"nt\">&gt;<\/span>\u30c8\u30c3\u30d7\u30da\u30fc\u30b8<span class=\"nt\">&lt;\/a&gt;<\/span>\r\n    <span class=\"nt\">&lt;table&gt;<\/span>\r\n        <span class=\"nt\">&lt;thead&gt;<\/span>\r\n            <span class=\"nt\">&lt;tr&gt;<\/span>\r\n                <span class=\"nt\">&lt;th<\/span> <span class=\"na\">scope=<\/span><span class=\"s\">\"col\"<\/span><span class=\"nt\">&gt;<\/span>\u30bf\u30a4\u30c8\u30eb<span class=\"nt\">&lt;\/th&gt;<\/span>\r\n                <span class=\"nt\">&lt;th<\/span> <span class=\"na\">scope=<\/span><span class=\"s\">\"col\"<\/span><span class=\"nt\">&gt;<\/span>\u611f\u60f3<span class=\"nt\">&lt;\/th&gt;<\/span>\r\n            <span class=\"nt\">&lt;\/tr&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/thead&gt;<\/span>\r\n        <span class=\"nt\">&lt;tbody&gt;<\/span>\r\n            <span class=\"nt\">&lt;tr<\/span> <span class=\"na\">th:each=<\/span><span class=\"s\">\"article : ${articleList}\"<\/span><span class=\"nt\">&gt;<\/span>\r\n                <span class=\"nt\">&lt;th<\/span> <span class=\"na\">scope=<\/span><span class=\"s\">\"col\"<\/span> <span class=\"na\">th:text=<\/span><span class=\"s\">\"${article.title}\"<\/span><span class=\"nt\">&gt;<\/span>(title)<span class=\"nt\">&lt;\/th&gt;<\/span>\r\n                <span class=\"nt\">&lt;td<\/span> <span class=\"na\">th:text=<\/span><span class=\"s\">\"${article.impressions}\"<\/span><span class=\"nt\">&gt;<\/span>(impression)<span class=\"nt\">&lt;\/td&gt;<\/span>\r\n            <span class=\"nt\">&lt;\/tr&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/tbody&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/table&gt;<\/span>\r\n<span class=\"nt\">&lt;\/body&gt;<\/span>\r\n<span class=\"nt\">&lt;\/html&gt;<\/span>\r\n<\/code><\/pre>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3dd637434c4406c88f9d\/23-0.png\" alt=\"image.png\" \/><\/div>\n<h2>\u7ed3\u675f<\/h2>\n<p>\u6211\u80fd\u591f\u4f7f\u7528Spring Boot\u521b\u5efa\u4e00\u4e2a\u7b80\u5355\u7684Web\u5e94\u7528\u7a0b\u5e8f\u3002\u56e0\u4e3a\u8fd8\u6709\u5f88\u591a\u6211\u4e0d\u77e5\u9053\u7684\u529f\u80fd\uff0c\u6240\u4ee5\u6211\u4f1a\u7ee7\u7eed\u63a2\u7d22\u3002<\/p>\n<p>\u6211\u5728\u4f7f\u7528VSCode\uff0c\u4e0d\u8fc7\u53ef\u80fd\u66f4\u597d\u7684\u662f\u7528IntelliJ\u5427\u3002\u65e0\u8bba\u5982\u4f55\uff0c\u6211\u5f88\u6ee1\u610f\u6700\u8fd1\u642d\u5efa\u7684\u73af\u5883\u80fd\u591f\u8fd0\u884c\u3002<\/p>\n<h2>\u8bf7\u53c2\u8003<\/h2>\n<p>Spring Boot + Spring MVC\u7684\u793a\u4f8b\u5e94\u7528\u5b9e\u73b0\u3002<br \/>\n\u3010SpringBoot\u3011\u521b\u5efaWeb\u5e94\u7528<br \/>\n\u3010Java\u3011Thymeleaf\u57fa\u7840\uff08SpringBoot\uff09<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u9996\u5148 \u682a\u5f0f\u4f1a\u793e\u30d4\u30fc\u30a2\u30fc\u30eb\u30aa\u30fc\uff08\u5e0c\u671b\u80fd\u5b9e\u73b0\uff01\uff09\u5c06\u8fce\u67652022\u5e74\u7684\u7b2c7\u5929\u5723\u8bde\u8282\u65e5\u5386\u3002 \u5728\u524d\u4e00\u5929\uff0c\u7531\u4e8e[AWS]SA [&hellip;]<\/p>\n","protected":false},"author":8,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-40012","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u5c1d\u8bd5\u4f7f\u7528SpringBoot MVC\u5b9e\u73b0\u4e00\u4e2a\u7b80\u5355\u7684WEB\u5e94\u7528 - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u5c1d\u8bd5\u4f7f\u7528springboot-mvc\u5b9e\u73b0\u4e00\u4e2a\u7b80\u5355\u7684web\u5e94\u7528\u3002\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u5c1d\u8bd5\u4f7f\u7528SpringBoot MVC\u5b9e\u73b0\u4e00\u4e2a\u7b80\u5355\u7684WEB\u5e94\u7528\" \/>\n<meta property=\"og:description\" content=\"\u9996\u5148 \u682a\u5f0f\u4f1a\u793e\u30d4\u30fc\u30a2\u30fc\u30eb\u30aa\u30fc\uff08\u5e0c\u671b\u80fd\u5b9e\u73b0\uff01\uff09\u5c06\u8fce\u67652022\u5e74\u7684\u7b2c7\u5929\u5723\u8bde\u8282\u65e5\u5386\u3002 \u5728\u524d\u4e00\u5929\uff0c\u7531\u4e8e[AWS]SA [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u5c1d\u8bd5\u4f7f\u7528springboot-mvc\u5b9e\u73b0\u4e00\u4e2a\u7b80\u5355\u7684web\u5e94\u7528\u3002\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-09-23T07:23:36+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-29T06:28:29+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3dd637434c4406c88f9d\/12-0.png\" \/>\n<meta name=\"author\" content=\"\u96c5, \u609f\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u96c5, \u609f\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"3 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82\/\",\"name\":\"\u5c1d\u8bd5\u4f7f\u7528SpringBoot MVC\u5b9e\u73b0\u4e00\u4e2a\u7b80\u5355\u7684WEB\u5e94\u7528 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-09-23T07:23:36+00:00\",\"dateModified\":\"2024-04-29T06:28:29+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/f044a4b7fa4ee2701702942002419ca6\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u5c1d\u8bd5\u4f7f\u7528SpringBoot MVC\u5b9e\u73b0\u4e00\u4e2a\u7b80\u5355\u7684WEB\u5e94\u7528\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/f044a4b7fa4ee2701702942002419ca6\",\"name\":\"\u96c5, \u609f\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/e71a913e914f1aad1efc391f92084294bac54bc782acd289638580134cf667a6?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/e71a913e914f1aad1efc391f92084294bac54bc782acd289638580134cf667a6?s=96&d=mm&r=g\",\"caption\":\"\u96c5, \u609f\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/yawu\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u5c1d\u8bd5\u4f7f\u7528SpringBoot MVC\u5b9e\u73b0\u4e00\u4e2a\u7b80\u5355\u7684WEB\u5e94\u7528 - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u5c1d\u8bd5\u4f7f\u7528springboot-mvc\u5b9e\u73b0\u4e00\u4e2a\u7b80\u5355\u7684web\u5e94\u7528\u3002\/","og_locale":"zh_CN","og_type":"article","og_title":"\u5c1d\u8bd5\u4f7f\u7528SpringBoot MVC\u5b9e\u73b0\u4e00\u4e2a\u7b80\u5355\u7684WEB\u5e94\u7528","og_description":"\u9996\u5148 \u682a\u5f0f\u4f1a\u793e\u30d4\u30fc\u30a2\u30fc\u30eb\u30aa\u30fc\uff08\u5e0c\u671b\u80fd\u5b9e\u73b0\uff01\uff09\u5c06\u8fce\u67652022\u5e74\u7684\u7b2c7\u5929\u5723\u8bde\u8282\u65e5\u5386\u3002 \u5728\u524d\u4e00\u5929\uff0c\u7531\u4e8e[AWS]SA [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u5c1d\u8bd5\u4f7f\u7528springboot-mvc\u5b9e\u73b0\u4e00\u4e2a\u7b80\u5355\u7684web\u5e94\u7528\u3002\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-09-23T07:23:36+00:00","article_modified_time":"2024-04-29T06:28:29+00:00","og_image":[{"url":"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d3dd637434c4406c88f9d\/12-0.png"}],"author":"\u96c5, \u609f","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u96c5, \u609f","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"3 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82\/","name":"\u5c1d\u8bd5\u4f7f\u7528SpringBoot MVC\u5b9e\u73b0\u4e00\u4e2a\u7b80\u5355\u7684WEB\u5e94\u7528 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-09-23T07:23:36+00:00","dateModified":"2024-04-29T06:28:29+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/f044a4b7fa4ee2701702942002419ca6"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u5c1d\u8bd5\u4f7f\u7528SpringBoot MVC\u5b9e\u73b0\u4e00\u4e2a\u7b80\u5355\u7684WEB\u5e94\u7528"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/f044a4b7fa4ee2701702942002419ca6","name":"\u96c5, \u609f","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/e71a913e914f1aad1efc391f92084294bac54bc782acd289638580134cf667a6?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/e71a913e914f1aad1efc391f92084294bac54bc782acd289638580134cf667a6?s=96&d=mm&r=g","caption":"\u96c5, \u609f"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/yawu\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e5%b0%9d%e8%af%95%e4%bd%bf%e7%94%a8springboot-mvc%e5%ae%9e%e7%8e%b0%e4%b8%80%e4%b8%aa%e7%ae%80%e5%8d%95%e7%9a%84web%e5%ba%94%e7%94%a8%e3%80%82\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/40012","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/8"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=40012"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/40012\/revisions"}],"predecessor-version":[{"id":85823,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/40012\/revisions\/85823"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=40012"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=40012"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=40012"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}