rest入门实践之二:get/post/put/delete
rest入门实践之二:get/post/put/delete
第一步:同样创建相应webservice工程
第二步:代码:
package com.rest.hello; import javax.ws.rs.DELETE; import javax.ws.rs.GET; import javax.ws.rs.POST; import javax.ws.rs.PUT; import javax.ws.rs.Path; import javax.ws.rs.PathParam; import javax.ws.rs.QueryParam; @Path("hello") public class Hello { @GET //查询 @Path("doGet") public String doGet(@QueryParam("id") String id) { System.out.println("doGet"); return id + "-doGet-" + "person"; } @POST //创建 @Path("doPost/{name}") public Object doPost(@PathParam("name") String name) { System.out.println("doPost"); return "doPost -" + "create "+ name + "person"; } @DELETE @Path("doDelete") public String doDelete(@QueryParam("id") String id) { System.out.println("doDelete"); return "doDelete - "+ "delete" + id + "person"; } @PUT @Path("doPut/{newName}") public String doPut(@PathParam("newName") String newName) { System.out.println("doPut"); return "doPut - " + "put" + "person name : " + newName; } }
第三:发布服务,启动tomcat
第四步:前台:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>My JSP 'index.jsp' starting page</title> <script type="text/javascript"> var xmlhttp ; function createXMLHttp(){ if(window.XMLHttpRequest){ xmlhttp = new XMLHttpRequest(); }else{ xmlhttp = new ActiveXObject("Microsoft.xmlhttp"); } }; function clickChange(action,method){ createXMLHttp(); if(action == "doGet"){ xmlhttp.open(method,"<%=basePath%>services/hello/"+action+"?id='mdj'",true); }else if(action == "doPost"){ xmlhttp.open(method,"<%=basePath%>services/hello/"+action+"/mdj",true); }else if(action == "doPut"){ xmlhttp.open(method,"<%=basePath%>services/hello/"+action+"/zyq",true); }else if(action == "doDelete"){ xmlhttp.open(method,"<%=basePath%>services/hello/"+action+"?id='zyq'",true); } xmlhttp.onreadystatechange = clickChangeCallBack; xmlhttp.send(null); } function clickChangeCallBack(){ if(xmlhttp.status == 200){ if(xmlhttp.readyState == 4){ alert(xmlhttp.responseText); } } } </script> </head> <body> <a onclick="clickChange('doGet','get')">get操作</a> <a onclick="clickChange('doPost','post')">post操作</a> <a onclick="clickChange('doPut','put')">put操作</a> <a onclick="clickChange('doDelete','delete')">delete操作</a> </body> </html>
第5步访问:http://localhost/RestPractice2/
第6步:结果如下:
TESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTESTTEST
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端