Android开发搞Web-Spring Boot 制作Web
背景
接上一篇文章:SpringBoot读写MySQL 后,我们已经可以从DB中动态的输出 数据库 中的数据给客户端使用。但这些还不够,因为客户端用到的不仅仅是API,还有WEB H5的页面。所以今天我们就来搭一个Spring Web页面。
环境准备
还是老三样,如果你前面跟着走过来的,那直接可以跳过了。
git,IDEA,Gradle
开始下载和运行WEB代码
援人以鱼不如授人以渔,那我们直接把Spring-boot的所有示例代码放出来:SpringBoot,截图如下:
data:image/s3,"s3://crabby-images/e80a2/e80a2c6814c75059f37dfd1dce83ca3d67916172" alt=""
上方截图中,看到有 spring-boot-samples,直接点进去,可以看到下面一堆堆的示例!
data:image/s3,"s3://crabby-images/b2139/b21396697d640714076401c915b5e26feecc468c" alt=""
这里我们写WEB页面,那就搜索:web-ui
下载我已写好的示例工程,然后通过IDEA导入工程。
git clone https://github.com/ssevening/SpringBootWithDocker.git
data:image/s3,"s3://crabby-images/397de/397de956d920d8bc38748522cc6f53404ad3d7b9" alt=""
如果有数据库,就修改为自己的数据库网址和数据库名称。
如果没有,连接上去,然后创建相应的DB
连接mysql: docker exec -it mysql bash
创建数据库:create datebase ssevening;
然后就可以到目录下去启动应用了,截图如下:
data:image/s3,"s3://crabby-images/bdc6d/bdc6d1e7485e6c5575c0aa7edf55446de11332ae" alt=""
至此,我们就可以测试一下我们写的页面了。首先访问: http://localhost:8080/Index.html, 访问后得到如下截图:
data:image/s3,"s3://crabby-images/8f39f/8f39f31954ccf295a38e846ee7e82f190925b353" alt=""
data:image/s3,"s3://crabby-images/49282/4928207f55cb757ad764ba7e65d749aa75e679ed" alt=""
data:image/s3,"s3://crabby-images/a81cb/a81cb593135942cc89b3641b7727f87c691cbac4" alt=""
data:image/s3,"s3://crabby-images/9d72e/9d72e57edc6efc9f4ae06b976cd4c854a9e75f60" alt=""
通过上面的几个页面,代表我们的:API服务,DB服务,静态资源网页,动态网页,都搞好了。
下面我们来看一下相应的代码。
WEB代码分析:
首先,我们看一下Gradle的依赖:
data:image/s3,"s3://crabby-images/e1155/e1155980de8486ac0f0ff8fc1ed8569d514f95b9" alt=""
添加好相应的application配置文件,SpringBoot讲究的是按约定编程,按它的规矩办事,一切就都运行好好的,把相应的文件都放正确的位置,一切也就运行好好的。
data:image/s3,"s3://crabby-images/36337/36337ce945e324832d4c8c189b8251c8c2269630" alt=""
然后我们先看欢迎页:http://localhost:8080/Index.html的代码。
data:image/s3,"s3://crabby-images/b3058/b3058ceec5890fbf38c897c4ed33e41a2cf87f43" alt=""
然后再看链接到的:http://localhost:8080/greeting?name=ssevening的代码。
data:image/s3,"s3://crabby-images/06cb7/06cb73434de117874330fedcc15545300e969f1d" alt=""
需要传递参数为:name,默认值World,这里我们传递的是ssevening.
然后向model中,传递了一个name参数,到页面中。
而return greeting
代表渲染模板是 greeting.html,我们也来看一下代码。
data:image/s3,"s3://crabby-images/1f40c/1f40c8df845adab345378b3e4e1f0cff243223b6" alt=""
这样子,在页面中,直接通过 ${name}
显示出我们参数传递的值。
通过参数传递,在页面上显示,这很正常,JS都可以做到这功能,那我们就换一种,通过DB查询返回当前用户的列表,我们看greetingall
对应的代码如下:
data:image/s3,"s3://crabby-images/cc4a6/cc4a68b8b01e1ab3123835bdeb9877ea6b449665" alt=""
这里通过查询数据库,然后把所有的用户都放到了users对象中,然后通过 greetingall.html
来渲染页面。
data:image/s3,"s3://crabby-images/6474d/6474d47c252955c3b7afc49e8209d16dd510dfa6" alt=""
上面直接把出对象,然后画了一个表格,循环把数据取出来!完成一次最简单的WEB DB的交互。
总结
看到这里,我们的小目标算是完成了一大步了,现在我们学会了搭API服务,通过API读取DB的数据,通过页面访问DB的数据,满足日常Android的开发需求,不成问题,但哥不喜欢丑逼的 http://localhost:8080/Index.html ,跑在本地,太Low了,好不容易做出来的东西,怎么也要部署到外网可以给别人访问到吧?
好,那下一篇,我们来讲应用的布署。
欢迎关注作者微信公众号,及时获得作者更新:
data:image/s3,"s3://crabby-images/00b90/00b90f94d217d45adc4f35f9029b1ed463dc647a" alt="微信公众号"
另外还建立了小密圈:圈主 和 嘉宾 都是业内顶尖开发者,开发的app被Google 编辑推荐,对性能,架构,图片,MD设计都有研究和深入,欢迎大家加入,提升自己,一起进步,互相帮助交流!
data:image/s3,"s3://crabby-images/8022b/8022bd81f91d8492117a513982a579a12dbde160" alt="小密圈"