hjr-JAVA:JAVA与PHP互相跨域接口编写与访问

本文介绍了如何使用JAVA和PHP编写API接口,并演示了不同语言间接口调用的方法,包括解决跨域问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#JAVA写接口
JAVA一般先编写个数据Model

	@ResponseBody //表示返回的是json对象
	@RequestMapping(value="/xxx", method = RequestMethod.GET)
	public Map<String,Object> xxx(Model model) {
		Map<String,Object> returnMsg = new HashMap<String,Object>();
		String str=new String("访问JAVA接口返回数据".getBytes("iso-8859-1"),"utf-8");//避免返回数据乱码
		returnMsg.put("msg",str );
		return returnMsg; 
	}

#PHP写接口

<?php
	$myArray=array("xx"=>"xx");
	$myArray["xxx"]="xxx";
	echo json_encode($myArray); 
?>

#PHP跨域访问JAVA

<?php
    function getHttpResponseGET($url) {
        $curl = curl_init($url);
        curl_setopt($curl, CURLOPT_HEADER, 0 ); 
        curl_setopt($curl,CURLOPT_RETURNTRANSFER, 1);
        $responseText = curl_exec($curl);
        curl_close($curl);
        return $responseText;
    }
	$hanzi = rawurlencode("汉字");  //传汉字需要先编码
    $url = 'http://xxx.xxx.xxx.xx/xx/xx/xx?xx=xxx&xx=xxx';
    var_dump($url);
    
    $responseText = getHttpResponseGET($url);
	$obj=json_decode($responseText);
	
	var_dump($responseText);
	echo $obj->xxx;	
?>


#JAVA跨域访问PHP

		<!--http请求-->
		<dependency>
			<groupId>commons-httpclient</groupId>
			<artifactId>commons-httpclient</artifactId>
			<version>3.1</version>
		</dependency>
		public static Map<String, String> KuaYu(String url,Map<String , String> map){

		Map<String, String> reMap = new HashMap<String, String>();
		try{
			if(map.size() == 0){
				reMap.put("outResult", "0");
				reMap.put("outResultReason", "无数据需要发送");
				return reMap;
			}
			HttpClient client = new HttpClient();
			//返回结果集
			JSONObject jsonObjectResult = new JSONObject();
			PostMethod postMethod = new PostMethod(url);
			client.getParams().setSoTimeout(15000);
			//Part[] parts = { new StringPart("accNumber", "13816032072"),new StringPart("password", "000000")}
			Part[] parts = new Part[map.size()];
			Map<String , String> mapParas = map;
			int i =0;
			for(Map.Entry<String, String> entry : mapParas.entrySet()){
				parts[i] = new StringPart(entry.getKey().trim(), entry.getValue().trim());
				i++;
			}
			//对于MIME类型的请求,httpclient建议全用MulitPartRequestEntity进行包装
			MultipartRequestEntity mre = new MultipartRequestEntity(parts, postMethod.getParams());
			postMethod.setRequestEntity(mre);
			//执行请求,返回状态码
			int status = client.executeMethod(postMethod);
			if (status == HttpStatus.SC_OK) {
				String result = postMethod.getResponseBodyAsString();
				result = new String(result.getBytes("ISO-8859-1"),"UTF-8");//汉字需要编码成UTF-8
				jsonObjectResult = JSONObject.parseObject(result);
				for(String key:jsonObjectResult.keySet()){
					reMap.put(key,jsonObjectResult.get(key).toString());
				}
				
			} else {
//              接口请求失败。
				reMap.put("outResult", "0");
				reMap.put("outResultReason", "请求失败。");
			}
		}catch(Exception e){
			e.printStackTrace();
			reMap.put("outResult", "0");
			reMap.put("outResultReason", "请求超时。");
		}
		return reMap;
	}


调用:


	Map<String , String> map = new HashMap<String , String>();
	map.put("xxx", "xxx");  
	map.put("xxx", "xxx");  
	String url = "http://xxx.xxx.xxx/xxx/xxx";	
	Map<String, String> mapResult = UrlUtil.KuaYu(url, map);

关于HJR-3FF系列功率继电器的数据手册、规格参数以及应用场景的信息如下: ### 规格参数 对于型号为HJR-3FF的功率继电器,这类元件通常属于工业级应用的产品。具体到HJR-3FF-S-Z这一款,其线圈工作电压有多种选择,比如常见的24VDC版本。此类型的继电器一般拥有较高的切换能力,在额定负载下能够可靠地接通和断开电路。 - **触点形式**:单刀双掷(SPDT)、多刀多掷等形式不等。 - **最大开关容量**:依据不同子型号而变化,但普遍能支持较高电流等级,如15安培甚至更高。 - **线圈电压**:涵盖直流交流范围内的多个标准值,像12VDC, 24VDC等都是较为普及的选择。 - **绝缘耐压**:确保了在高电压环境下的安全性,典型数值可能达到数千伏特以上。 - **机械寿命/电气寿命**:表示继电器可以承受的操作次数限制,这取决于制造商的设计标准。 请注意实际产品的详细技术指标应以厂商提供的最新数据手册为准,因为随着时间推移和技术进步,某些性能可能会有所调整或优化。 ### 应用场景 HJR-3FF系列功率继电器适用于需要频繁操作大电流回路的应用场合,例如但不限于: - 工业自动化控制系统中的电机启动停止控制; - 家电产品内部用于管理加热元件或其他耗电量较大的组件; - 新能源领里光伏逆变器、风力发电机组件间的电力传输路径转换; - 汽车行业中涉及引擎管理系统或是辅助驾驶系统的电源分配单元; 为了获取最准确的技术文档和支持材料,建议直接联系供应商或者访问官方网站查询对应型号的具体资料。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

架构师小侯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值