Java如何向外提供接口
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java如何向外提供接口相关的知识,希望对你有一定的参考价值。
A项目向B项目推送数据,现在需要A项目向B项目提供接口,(协议为HTTP,请求方式为POST,格式为JSON,请求地址为h t t p : / / xx / yy / zz . j h t m l,请求参数:string,string1……,返回Json),括号中的内容为B项目人员提供的接口文档,请问大侠A项目中这个接口怎么写呀?是否可附带上demo,多谢!!!
public static String sendPostUrl(String url, String param, String charset)PrintWriter out = null;
BufferedReader in = null;
String result = "";
try
URL realUrl = new URL(url);
// 打开和URL之间的连接
URLConnection conn = realUrl.openConnection();
// 设置通用的请求属性
conn.setRequestProperty("accept", "*/*");
conn.setRequestProperty("connection", "Keep-Alive");
conn.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
// 发送POST请求必须设置如下两行
conn.setDoOutput(true);
conn.setDoInput(true);
// 获取URLConnection对象对应的输出流
out = new PrintWriter(conn.getOutputStream());
// 发送请求参数
out.print(param);
// flush输出流的缓冲
out.flush();
// 定义BufferedReader输入流来读取URL的响应
in = new BufferedReader(new InputStreamReader(conn.getInputStream(), charset));
String line;
while ((line = in.readLine()) != null)
result += line;
catch (Exception e)
System.out.println("发送 POST 请求出现异常!" + e);
e.printStackTrace();
// 使用finally块来关闭输出流、输入流
finally
try
if (out != null)
out.close();
if (in != null)
in.close();
catch (IOException ex)
ex.printStackTrace();
return result;
参考技术A 接口中用httpClient.去访问B项目的URL传递参数...追问
我没写过这个东西,能不能提供一个demo。多谢!!!
参考技术B其实,就是要你提供一个JSP、action或servlet路径,在这路径后台中,你接收他传过来的一系列参数,处理后,输出结果(json)。
比如,你写一个test.jsp如下:
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%><%
out.println("\\"code\\":\\"1212\\", \\"name\\":\\"user-1\\", \\"age\\":\\"22\\"");
%>
然后http://localhost/test.jsp就是提供给他的接口地址,此时如果他访问,得到的结果应该是:
"code":"1212", "name":"user-1", "age":"22"至于out.println的输出结果,应该是你要提供给他的数据。
对的,就是我要提供数据给他。就是我提供接口,为的就是传数据给他。那些参数就是我要给他的数据。
参考技术C 你写个servlet,在web.xml里映射到这个地址,然后再dopost方法里将返回内容写成JSON格式,再用reponse.out输出就可以了。追问还在在web.xml里映射?映射servlet还是我那个jhtml的地址?
追答把那个jhtml请求映射servlet
参考技术D http://www.oschina.net/question/998893_176194java给别人提供接口,接口安全怎么保证
我们在开发过程中,肯定会有和第三方或者app端的接口调用。在调用的时候,下面的方法可以来防止非法链接或者恶意攻击。
一、签名
根据用户名或者用户id,结合用户的ip或者设备号,生成一个token。在请求后台,后台获取http的head中的token,校验是否合法(和数据库或者Redis中记录的是否一致,在登录或者初始化的时候,存入数据库/redis)
在使用Base64方式的编码后,Token字符串还是有20多位,有的时候还是嫌它长了。由于GUID本身就有128bit,在要求有良好的可读性的前提下,很难进一步改进了。那我们如何产生更短的字符串呢?还有一种方式就是较少Token的长度,不用GUID,而采用一定长度的随机数,例如64bit,再用Base64编码表示:
var rnd = new Random();
var tokenData = userIp+userId;
rnd.NextBytes(tokenData);
var token = Convert.ToBase64String(tokenData).TrimEnd('=');
由于这里只用了64bit,此时得到的字符串为Onh0h95n7nw的形式,长度要短一半。这样就方便携带多了。但是这种方式是没有唯一性保证的。不过用来作为身份认证的方式还是可以的(如网盘的提取码)。
二、加密
客户端和服务器都保存一个秘钥,每次传输都加密,服务端根据秘钥解密。
客户端:
1、设置一个key(和服务器端相同)
2、根据上述key对请求进行某种加密(加密必须是可逆的,以便服务器端解密)
3、发送请求给服务器
服务器端:
1、设置一个key
2、根据上述的key对请求进行解密(校验成功就是「信任」的客户端发来的数据,否则拒绝响应)
3、处理业务逻辑并产生结果
4、将结果反馈给客户端
三、第三方支持
比如spring security-oauth
参考技术A 0赞同反对,不会显示你的姓名Java前景更广阔,毕竟powercenter只是一个ETL工具.当然如果题主所处的环境正需要精通powercenter的人才,你也觉得靠它能养活你一辈子,那么选择powercenter也未尝不可.显示全部
Java前景更广阔,毕竟powercenter只是一个ETL工具.
当然如果题主所处的环境正需要精通powercenter的人才,你也觉得靠它能养活你一辈子,那么选择powercenter也未尝不可.本回答被提问者采纳 参考技术B 给别人的数据是你想给的啊 可以用post 在参数中加验证 或者你和别人商量一下用加密算法
以上是关于Java如何向外提供接口的主要内容,如果未能解决你的问题,请参考以下文章
Android组件系列----ContentProvider内容提供者