系列文章
- 秋名山涧--给班长的开车APP -- 用爬虫webmagic爬取数据(一)
- 秋名山涧--给班长的开车APP -- 用MySql结合JDBC保存数据到数据库(二)
- 秋名山涧--给班长的开车APP -- 用Rest API制作API接口(三)
Rest API服务用的是Jersey
Json结构如图
model结构图.png现在目标很明确了,我们只需要从数据库里面读数据出来构造出List<MeiziModel>对象然后用fastJson之类的工具转换,幸运的是,Jersey支持此装换。
如何创建一个新的Jersey项目
这里用的是IDEA和Tomcat8.0,当然,你用别的也行,
1 新建一个JAVA EE项目,勾选RESTful Web Service
选中下面的download,这里需要科学上网设置代理啥的才能正常下载到jar包
项目右键Add Frameworks Support勾选Web Application和下方的Maven
在pom.xml文件中<project>节点下加入
<dependencies>
<!-- https://mvnrepository.com/artifact/org.glassfish.jersey.containers/jersey-container-servlet -->
<dependency>
<groupId>org.glassfish.jersey.containers</groupId>
<artifactId>jersey-container-servlet</artifactId>
<version>2.23</version>
</dependency>
<!--下面的是爬虫的相关依赖-->
<dependency>
<groupId>us.codecraft</groupId>
<artifactId>webmagic-core</artifactId>
<version>0.7.1</version>
</dependency>
<dependency>
<groupId>us.codecraft</groupId>
<artifactId>webmagic-extension</artifactId>
<version>0.7.1</version>
</dependency>
<!--用于支持对象转json服务-->
<dependency>
<groupId>com.fasterxml.jackson.jaxrs</groupId>
<artifactId>jackson-jaxrs-json-provider</artifactId>
<version>2.7.4</version>
</dependency>
<!--MySQL-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.25</version>
</dependency>
</dependencies>
开启自动导包
打开Project Structure,配置Artifacts
注意的是箭头的几个地方
右边的很多是很多jar包,对着Test2点击右键
将他们添加到web项目中
其他的是导出war包用的,先别管
修改web文件夹中WEB-INF文件夹中的web.xml文件
<!--json application需要的入口-->
<servlet>
<servlet-name>Way REST Service</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>javax.ws.rs.Application</param-name>
<!--这个是自定义的application的位置-->
<param-value>com.minminaya.RestApplication</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Way REST Service</servlet-name>
<!--这里决定了访问的链接入口,比如这里是api,那么http://localhost:8080/api/hello是访问链接-->
<url-pattern>/api/*</url-pattern>
</servlet-mapping>
在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<MeiziModel>对象就可以了
文件结构
文件结构在HelloJsersy中添加
/**
* 用于测试
*/
@GET
@Path("/getuser")
@Produces(MediaType.APPLICATION_JSON + ";charset=utf8")
public List<MeiTuModel> getUserJson() {
//下面注释的是测试代码
// List<User> users = new ArrayList<User>();
// 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<MeiTuModel> meiTuModels = sqlUtilForSelectData.selectDataFormeiziweboneTable(1, 2);
return meiTuModels;
}
运行
运行针对请求图片有页面数量和页码,设计了这个请求参数
这篇文章介绍了Jersey 请求参数
当然最好是去看Jersey的文档
//获取数据
@GET
@Path("/pic")
@Produces(MediaType.APPLICATION_JSON + ";charset=utf8")
public List<MeiTuModel> 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<MeiTuModel> meiTuModels = sqlUtilForSelectData.selectDataFormeiziweboneTable(realStart, realEnd);
return meiTuModels;
}
比如要返回8个结果,第2页,那么
部署到服务器
导出war文件
在Project Structure里面
接着
去输出目录找war文件
Paste_Image.png最好把导出名字简单的,比如改成AAA,那么这里访问时是AAA/api/hello
部署过程
1 先把war复制到Tomcat的webapps文件夹下
2 数据源配置(分为全局和局部),我懒,直接用的全局,就因为他们在一个文件夹里面
- 在Tomcat的conf文件夹修改context.xml文件,在最底下加入
<Resource name="jdbc/meizitu"
<!--meizitu是数据库名-->
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文件,在最下面加入应用上面的配置
```
<resource-ref>
<description>DB Connection</description>
<res-ref-name>jdbc/meizitu</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
```
**去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 !
网友评论