系列文章
- 秋名山涧--给班长的开车APP -- 用爬虫webmagic爬取数据(一)
- 秋名山涧--给班长的开车APP -- 用MySql结合JDBC保存数据到数据库(二)
- 秋名山涧--给班长的开车APP -- 用Rest API制作API接口(三)
Rest API服务用的是Jersey
Json结构如图
现在目标很明确了,我们只需要从数据库里面读数据出来构造出List
如何创建一个新的Jersey项目
这里用的是IDEA和Tomcat8.0,当然,你用别的也行,
1 新建一个JAVA EE项目,勾选RESTful Web Service
选中下面的download,这里需要科学上网设置代理啥的才能正常下载到jar包
项目右键Add Frameworks Support勾选Web Application和下方的Maven
在pom.xml文件中
org.glassfish.jersey.containers
jersey-container-servlet
2.23
us.codecraft
webmagic-core
0.7.1
us.codecraft
webmagic-extension
0.7.1
com.fasterxml.jackson.jaxrs
jackson-jaxrs-json-provider
2.7.4
mysql
mysql-connector-java
5.1.25
开启自动导包
打开Project Structure,配置Artifacts
注意的是箭头的几个地方
右边的很多是很多jar包,对着Test2点击右键
将他们添加到web项目中
其他的是导出war包用的,先别管
修改web文件夹中WEB-INF文件夹中的web.xml文件
Way REST Service
org.glassfish.jersey.servlet.ServletContainer
javax.ws.rs.Application
com.minminaya.RestApplication
1
Way REST Service
/api/*
在com.minminaya包中创建类RestAplication
/** 用于注册对象转json服务
* Created by Niwa on 2017/7/8.
*/
public class RestApplication extends ResourceConfig {
public RestApplication() {
//很重要,包名错误直接导致访问错误
packages("com.minminaya");
register(JacksonJsonProvider.class);
}
}
注意代码中注释所说,QAQ
新建一个类HelloJsersy,简单测试Jersey能不能用
package com.minminaya;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
/**
* Created by Niwa on 2017/7/8.
*/
@Path("hello")
public class HelloJsersy {
@GET
//后面的charset=utf8只是为了支持中文不乱码
@Produces("application/json;charset=utf8")
public String getString() {
return "我是美女";
}
}
点击右上角的的Tomcat运行,Tomcat有时候会抽风
显示成这样
什么都没有,正常情况下这里应该是
这个是index.jsp的默认的内容
只好重新配置服务器了
点击左上角的加号,不是Default里面的Tomcat
重新配置服务器
然后启动得到上面的$End$内容的网页说明Tomcat启动成功
浏览器输入http://localhost:8080/api/hello
说明Jersey服务正常了。
现在剩下的是把前面2篇的爬虫程序拷贝过来,最后得到List
文件结构
在HelloJsersy中添加
/**
* 用于测试
*/
@GET
@Path("/getuser")
@Produces(MediaType.APPLICATION_JSON + ";charset=utf8")
public List getUserJson() {
//下面注释的是测试代码
// List users = new ArrayList();
// User user = new User();
// user.setAge(27);
// user.setUserid("005");
// user.setUsername("Fmand");
//
//
// for (int i = 0; i < 5; i++) {
// users.add(user);
// }
// return users;
SqlUtilForSelectData sqlUtilForSelectData = new SqlUtilForSelectData();
//查询所需对象直接返回就是json文件
List meiTuModels = sqlUtilForSelectData.selectDataFormeiziweboneTable(1, 2);
return meiTuModels;
}
运行
针对请求图片有页面数量和页码,设计了这个请求参数
这篇文章介绍了Jersey 请求参数
当然最好是去看Jersey的文档
//获取数据
@GET
@Path("/pic")
@Produces(MediaType.APPLICATION_JSON + ";charset=utf8")
public List getMeiziJson(@QueryParam("size") int size,
@QueryParam("offset") int offset) {
int realStart = size * (offset - 1) + 1;
int realEnd = realStart + size - 1;
SqlUtilForSelectData sqlUtilForSelectData = new SqlUtilForSelectData();
List meiTuModels = sqlUtilForSelectData.selectDataFormeiziweboneTable(realStart, realEnd);
return meiTuModels;
}
比如要返回8个结果,第2页,那么
部署到服务器
导出war文件
在Project Structure里面
接着
去输出目录找war文件
最好把导出名字简单的,比如改成AAA,那么这里访问时是AAA/api/hello
部署过程
1 先把war复制到Tomcat的webapps文件夹下
2 数据源配置(分为全局和局部),我懒,直接用的全局,就因为他们在一个文件夹里面
- 在Tomcat的conf文件夹修改context.xml文件,在最底下加入
auth="Container"
type="javax.sql.DataSource"
maxActive="100"
maxIdle="30"
maxWait="10000"
username="root"
password="123456"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/meizitu"/>
```
- 修改同样是此目录下的web.xml文件,在最下面加入应用上面的配置
```
DB Connection
jdbc/meizitu
javax.sql.DataSource
Container
```
**去bin文件夹里面启动startup.bat完成部署**
---
**数据源配置参考:**
[Tomcat部署web项目指导(部署及数据源配置](http://www.cnblogs.com/anobugworld/p/7112297.html)
[Tomcat下的war包数据源配置](http://hanqunfeng.iteye.com/blog/1169370)
---
**Jersey参考**
[Jersey官方文档](https://waylau.gitbooks.io/jersey-2-user-guide/content/)
[Jersey 入门与Javabean](http://www.cnblogs.com/xinsheng/p/3897289.html)
[Jersey学习记录(一)--环境配置](http://blog.csdn.net/u012706811/article/details/52054153)
[java实现REST方式的webService](http://www.cnblogs.com/Mr-kevin/p/5806928.html)
[IntelliJ上创建Tomcat + Jersey 工程](http://blog.csdn.net/felcon/article/details/51832146)
[使用Java创建RESTful Web Service](http://www.importnew.com/7336.html)
[用Jersey构建RESTful服务3--JAVA对象转成JSON输出](http://blog.csdn.net/kkkloveyou/article/details/21485243)
---
源代码:**[MeiziTuSpider](https://github.com/minminaya/MeiziTuSpider)**
---
---
The End !