java web开发(四) 接口开发补坑1
来源:互联网 发布:矢仓枫子 知乎 编辑:程序博客网 时间:2024/05/22 16:35
好久都没写博客了,最近的工作重点是H5以及JavaScript方面的!后面要是有时间,会一直推出博文!
今天的博文是补坑的!之前写了几篇有关java web接口开发的文章,有的朋友留言,说项目导入的时候有问题,或者说代码有的地方看不懂,等等其他问题。那么今天就来说说这些问题!如果你还没了解之前的接口博文,请先看java web开发(二) 接口开发!
一、项目导入报错。
从csdn资源下载的代码,由Eclipse导入后,正常情况下,应该是会报错的!这个主要是我在导入项目的时候,没有将依赖的jar导入至lib目录中,所以导入项目的时候,很有可能会报错报错截图如下,
因为这个javax.servlet.* 包用的是Tomact下的 servlet-api.jar。
这个问题的解决办法是有2种,
方法1,从Tomact中的lib中找到这个servlet-api.jar,复制到项目的lib目录下,然后在这个jar上右键--->Build Path--->Add Build Path,即可!
方法2, 选项目右键--->Properties--->Java Build Path--->Libraries--->Add Library--->Server RunTime点击next,然后选择你的本地Tomact server--->Finish,最后点击Apply--->OK即可!
大功告....!结果可能还是报错了!就像这样的,看截图
这个错误是说,这个项目之前使用的是Tomact v6.0,而我现在给他配置的是 Tomact v8.5!
这个解决方法网上就比较多了!打开项目settings目录 org.eclipse.wst.common.project.facet.core.xml文件,
删除 <runtime name="Apache Tomcat v6.0"/> 这一行,保存!然后刷新项目!这个错误就没了!但是,你可能还会遇到其他的错误,例如提示说,jre的版本不匹配,那么就需要修改项目使用的jre版本!
这里就不详细列举各种各样的问题的解决方法了,如果有问题,就自行百度吧!相信,你可以的!
二、项目代码详解。
这个地方主要是把之前在 java web开发(二) 接口开发写的中的代码,再次梳理!让小伙伴们在本篇博文中就可以直观的看出项目结构,以及主要代码!下面先给出整个项目的目录结构树,如下图所示,
下面一一来介绍这些包以及类,
1. cn.xinxing.action.student 这个包中是放置接口的,也就是向外部调用提供接口!下面我们就看看具体接口的代码,
package cn.xinxing.action.student;import java.io.IOException;import java.util.List;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import cn.xinxing.business.StudentBusiness;import cn.xinxing.json.core.ListObject;import cn.xinxing.json.responseUtils.ResponseUtils;import cn.xinxing.json.status.StatusHouse;import cn.xinxing.json.utils.JackJsonUtils;import cn.xinxing.model.Students;/** * Servlet implementation class StudentInq */public class StudentInq extends HttpServlet {private static final long serialVersionUID = 1L; /** * @see HttpServlet#HttpServlet() */ public StudentInq() { super(); // TODO Auto-generated constructor stub }/** * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) */protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {// TODO Auto-generated method stubList<Students> list = StudentBusiness.getAllStudents();ListObject listObject=new ListObject();listObject.setItems(list);listObject.setStatusObject(StatusHouse.COMMON_STATUS_OK);String responseText = JackJsonUtils.toJson(listObject);ResponseUtils.renderJson(response, responseText);}/** * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) */protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {// TODO Auto-generated method stubdoGet(request, response);}}代码比较简单,就不多说了,相信看过java web开发(二) 接口开发的知道。但是,为了这篇文章,还是多说一句吧!这个类是继承自HttpServlet的,也就是说这个类其实是一个Servlet类,它内部提供了doGet()和doPost()方法,这两个方法其实就是我们经常所说的get请求和post请求,而get请求和post请求这两种请求方式,相信了解http请求的,都知道,get请求就是将请求参数直接放到请求路径后,post请求是将请求参数放置到请求的body中,当然他们还有其他一些区别,这里就不多说了!我们经常使用的是post请求。而demo中为了方便测试,就只实现了get请求。下面看看doGet()方法,
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {// TODO Auto-generated method stubList<Students> list = StudentBusiness.getAllStudents(); // 从数据库获取学生数据列表ListObject listObject=new ListObject(); // 创建一个返回对象listObject.setItems(list);// 将数据列表设置给返回对象的items属性listObject.setStatusObject(StatusHouse.COMMON_STATUS_OK);// 设置返回对象的响应状态码String responseText = JackJsonUtils.toJson(listObject);//将返回对象转换为json字符串ResponseUtils.renderJson(response, responseText);//将结果返回会调用者}每一行代码都加入了注释,不难理解!有一个地方需要强调一点,就是设置返回的响应状态码,好多小伙伴对这儿疑问比较大,这里再强调一下,这里设置的响应状态码是主要为了让调用者收到返回的json结果字符串后解析json时用的,简单来说,就是,
a). 如果响应状态码等于‘ok’时,调用者才去解析结果字符串;
b).如果是其他状态码,就直接显示结果字符串中的‘msg’。
这个是我自己定义的规则!大家自己在实际开发中,完全可以按照自己的方式去定义解析规则!
好了,有关对外提供的接口类,就说到这里。
2. cn.xinxing.business 这个包是和数据相关的。连接数据库以及从数据库中获取数据!其中DBHelper这个类是连接数据库的。这里我没有使用引入其他框架来维护数据库以及数据处理!下面看看这个类的具体实现,
package cn.xinxing.business;import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.SQLException;/** */public class DBHelper { public static final String url = "jdbc:mysql://localhost:3306/students_manage"; //数据库url public static final String name = "com.mysql.jdbc.Driver"; //JDBC driver name public static final String user = "root"; //数据库用户名 public static final String password = "111111";// 数据库密码 public Connection conn = null; //数据库连接对象 public PreparedStatement pst = null; //对象 /** * @param sql */ public DBHelper(String sql) { try { Class.forName(name);//注册JDBC driver conn = DriverManager.getConnection(url, user, password);//打开一个数据库连接 pst = conn.prepareStatement(sql);//执行sql后,创建了preparedStatemen对象 } catch (Exception e) { e.printStackTrace(); } } /** * 关闭数据库 */ public void close() { try { this.conn.close(); //关闭连接 this.pst.close(); //关闭对象 } catch (SQLException e) { e.printStackTrace(); } } }通过JDBC连接至MySql数据库,然后获取到一个PreparedStatement对象,通过这个对象来发送sql命令,并且从数据库接收数据的属性和方法,换句话说,通过这个对象,我们就可以拿到数据库中的相关数据。
接着看StudentBusiness是如何获取数据的,还是上代码,
package cn.xinxing.business;import java.sql.ResultSet;import java.sql.SQLException;import java.util.ArrayList;import java.util.List;import cn.xinxing.model.Students;/** * 从数据库中获取数据 */public class StudentBusiness {/** * 获取所有的学生数据 * @return */public static List<Students> getAllStudents() {List<Students> list = new ArrayList<Students>();//list对象String sql = null;DBHelper db1 = null;sql = "select *from student";// SQLdb1 = new DBHelper(sql);//创建DBHelper对象ResultSet ret = null;//创建结果集对象,执行sql后返回的数据集合try {ret = db1.pst.executeQuery();//这个方法就类似于执行了SELECT语句一样!while (ret.next()) {int id = ret.getInt(1);//第一列是idString name = ret.getString(2);//第二列是nameint age = ret.getInt(3);//第三列是ageint sex = ret.getInt(4);//第四列是sexStudents students = new Students();//创建students对象students.setId(id);//设置idstudents.setName(name);//设置namestudents.setAge(age);//设置agestudents.setSex(sex);//设置sexlist.add(students);//将students对象放置到列表中} //循环从结果集中获取数据并设置到list列表对象中ret.close();//关闭对象db1.close();//关系数据库连接} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();} //return list;//返回结果}/** * 通过id来获取某个学生数据 * @param _id * @return */public static Students getStudentInfoById(String _id) {String sql = null;DBHelper db1 = null;sql = "select * from student where id =" + _id;// sqldb1 = new DBHelper(sql);//创建DBHelper对象ResultSet ret = null;//创建结果集对象Students students = new Students();//创建对象try {ret = db1.pst.executeQuery();//正常来说,这个结果集只有一个对象while (ret.next()) {int id = ret.getInt(1);//第一列是idString name = ret.getString(2);//第二列是nameint age = ret.getInt(3);//第三列是ageint sex = ret.getInt(4);//第四列是sexint mobile = ret.getInt(5);//第五列是mobilestudents.setId(id);//设置idstudents.setName(name);//设置namestudents.setAge(age);//设置agestudents.setSex(sex);//设置sexstudents.setMobile(mobile);//设置mobile} //循环从结果集中获取数据并设置到对象中(正常来说,这个循环只执行一次)ret.close();//关闭对象db1.close();//关系数据库连接} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();} // return students;//返回结果}}
这个类提供了两个方法获取数据,一个方法是获取数据库中学生表中的所有数据,一个根据id参数获取某一个学生的数据。这里用到了PreparedStatement对象,如果对这个对象了解更多,请看JDBC教程!
最后补上,例子下载地址。
由于篇幅问题,下篇文章将继续来详解demo项目的代码! 博文中如果有误,欢迎指出! java web开发(五) 接口开发补坑2已经推出了!欢迎大家收看!
- java web开发(四) 接口开发补坑1
- java web开发(五) 接口开发补坑2
- JAVA WEB接口开发简述
- Java Web 开发后续(四)
- java web开发(二) 接口开发
- java web开发(二) 接口开发
- java web开发(二) 接口开发
- java web HttpClient 开发一个接口
- Java Web开发详解:RequestDispatcher接口
- java web开发(三) 接口使用
- java web开发(三) 接口使用
- Java Web开发Basic(四) JSON
- web接口开发经验
- Web API 开发接口
- 小程序开发补坑
- java web开发学习-19 JNDI接口简介
- 如何在java Web项目中开发WebService接口
- 如何在java Web项目中开发WebService接口
- Android BroadcastReceiver之电话录音
- python实现给定一个字符串,寻找最长非重复子串
- D
- Java中线程安全(synchronized)
- Java菜鸟学习日记25
- java web开发(四) 接口开发补坑1
- android bionic linker debug enable
- 视频笔记
- ? 枚举类实现接口
- 小白教你学习c++(6)几种常见的类型转换
- Qt Socket 多线程操作
- 【BFS+状压】HDU_5025_ Saving Tang Monk
- ORACLE 中的 ROW_NUMBER() OVER() 分析函数的用法
- String,StringBuffer与StringBuilder的区别