服务端的WEB架构采用的是SpringMVC。下面我们就直接说如何实现。
【1】Web.xml中的配置
<!--配置中央控制器 -->
<servlet>
<servlet-name>itooApi</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--配置从哪加载配置文件 -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>itooApi</servlet-name>
<!--所有访问的地址都由DispatcherServlet进行解析 -->
<url-pattern>/</url-pattern>
</servlet-mapping>
【2】springmvc.xml中的配置
<!--配置注解映射器和适配器 (这样不需要单独配置json转化器)必需 -->
<mvc:annotation-driven></mvc:annotation-driven>
<!-- 对于注解的Handler可以单个配置,实际开发中建议使用组件扫描 -->
<!-- 可以扫描controller、service、...这里让扫描controller,指定controller的包 -->
<!-- <context:component-scan base-package="com.tgb.itoo.controller"></context:component-scan> -->
<bean class="com.tgb.itoo.controller.CourseController" />
<bean class="com.tgb.itoo.controller.IndexController" />
<!-- 视图解析器 解析jsp解析,默认使用jstl标签,classpath下的得有jstl的包 -->
<bean
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- 配置jsp路径的前缀 -->
<property name="prefix" value="/WEB-INF/jsp/"/>
<!-- 配置jsp路径的后缀 -->
<property name="suffix" value=".jsp"/>
</bean>
<!--因为在web.xml中配置的url-pattern所有的都由DispatcherServlet处理,而静态文件不需要,所以按如下配置 -->
<mvc:resources location="WEB-INF/js/" mapping="/js/**"/>
<mvc:resources location="img/" mapping="/img/**"/>
【3】Controller中方法的写法
package com.tgb.itoo.controller;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import com.tgb.itoo.vo.Course;
/**
* @author xuchenyang
* @version 2016年3月19日16:35:25
*/
@Controller
public class CourseController {
/**
* 获得一门课程
* @param studentId
* @param courseid
* @return
*/
@RequestMapping(value="/student/{studentId}/course/{courseId}",method=RequestMethod.GET)
@ResponseBody
public Course GetCourse(@PathVariable("studentId") String studentId,@PathVariable("courseId") String courseid){
Course course=new Course();
course.setId(courseid);
course.setCode("0002");
course.setCourseName("高等数学");
//response.setHeader("Access-Control-Allow-Origin", "*"); //允许哪些url可以跨域请求到本域
return course;
}
/**
* 获得课程列表
* @return
*/
@RequestMapping(value="/student/{id}/course",method=RequestMethod.GET)
@ResponseBody
public List<Course> GetCourseList(@PathVariable("id") String studentId){
//定义课程
Course course1=new Course();
course1.setId("1");
course1.setCode("0001");
course1.setCourseName("大学语文");
//定义课程
Course course2=new Course();
course2.setId("2");
course2.setCode("0002");
course2.setCourseName("高等数学");
//将课程添加到集合中并返回
List<Course> courseList=new ArrayList<Course>();
courseList.add(course1);
courseList.add(course2);
return courseList;
}
/**
* 添加一门课程
* @return
*/
@RequestMapping(value="/student/{studentId}/course",method=RequestMethod.POST)
@ResponseBody
public String SaveCourse(@PathVariable("studentId") String studentId,@RequestBody Course course){
//保存course对象到数据库
//给课程生成ID
course.setId("8");
System.out.println("courseid:"+course.getId()+" code:"+course.getCode()+" name:"+course.getCourseName());
StringBuilder sb=new StringBuilder();
sb.append("{\"result\":true}");
return sb.toString();
}
/**
* 修改一门课程
* @return
*/
@RequestMapping(value="/student/{studentId}/course/{courseId}",method=RequestMethod.PUT)
@ResponseBody
public String UpdateCourse(@PathVariable("studentId") String studentId,@PathVariable("courseId") String courseid,@RequestBody Course course){
//保存course对象到数据库
//course.setId(courseid);
System.out.println("courseid:"+course.getId()+" code:"+course.getCode()+" name:"+course.getCourseName());
StringBuilder sb=new StringBuilder();
sb.append("{\"result\":true}");
return sb.toString();
}
/**
* 删除一门课程
* @return
*/
@RequestMapping(value="/student/{studentId}/course/{courseId}",method=RequestMethod.DELETE)
@ResponseBody
public String DeleteCourse(@PathVariable("studentId") String studentId,@PathVariable("courseId") String courseid){
StringBuilder sb=new StringBuilder();
System.out.println("删除的课程的id:"+courseid);
sb.append("{\"result\":true}");
return sb.toString();
}
}
【注意】:
@RequestBody:表示传入的是JSON格式的数据
@ResponseBody:表示返回的是JSON格式的数据
@RequestMapping(value=”/student/{studentId}/course/{courseId}”,method=RequestMethod.GET)表示请求的路径和请求的类型
@PathVariable:用此注解来表示方法 中的参数和RequestMapping中的请求路径中的参数的对应关系。PathVariable(“studentId”) 括号中的名称必须和路径中的参数占位符的名称一致。但是方法中参数的名称任意。
【4】测试
服务端如何去测试给移动端提供的接口返回的数据是否正确?可以写一个JSP页面通过$.Ajax测试不同类型的请求