|
|
|
@ -1,12 +1,15 @@
|
|
|
|
|
package org.jeecg.modules.ai.service.impl;
|
|
|
|
|
|
|
|
|
|
import java.io.StringReader;
|
|
|
|
|
import java.net.URL;
|
|
|
|
|
import java.util.Date;
|
|
|
|
|
import java.util.HashMap;
|
|
|
|
|
import java.util.Iterator;
|
|
|
|
|
import java.util.Map;
|
|
|
|
|
|
|
|
|
|
import javax.annotation.Resource;
|
|
|
|
|
import javax.xml.namespace.QName;
|
|
|
|
|
import javax.xml.ws.Service;
|
|
|
|
|
|
|
|
|
|
import org.dom4j.Document;
|
|
|
|
|
import org.dom4j.Element;
|
|
|
|
@ -20,9 +23,9 @@ import org.jeecg.modules.system.entity.SysAnnouncement;
|
|
|
|
|
import org.jeecg.modules.system.entity.SysAnnouncementSend;
|
|
|
|
|
import org.jeecg.modules.system.service.ISysAnnouncementSendService;
|
|
|
|
|
import org.jeecg.modules.system.service.ISysAnnouncementService;
|
|
|
|
|
import org.jeecg.modules.system.util.WebServiceUtil;
|
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
|
import org.springframework.beans.factory.annotation.Value;
|
|
|
|
|
import org.springframework.stereotype.Service;
|
|
|
|
|
|
|
|
|
|
import com.alibaba.fastjson.JSONObject;
|
|
|
|
|
import com.baomidou.dynamic.datasource.annotation.DS;
|
|
|
|
@ -37,18 +40,20 @@ import cn.hutool.http.webservice.SoapUtil;
|
|
|
|
|
* @Date: 2023-11-30
|
|
|
|
|
* @Version: V1.0
|
|
|
|
|
*/
|
|
|
|
|
@Service
|
|
|
|
|
@org.springframework.stereotype.Service
|
|
|
|
|
@DS("multi-datasource1")
|
|
|
|
|
public class RoomServiceImpl extends ServiceImpl<RoomMapper, Room> implements IRoomService {
|
|
|
|
|
|
|
|
|
|
@Resource
|
|
|
|
|
private RoomMapper roomMapper;
|
|
|
|
|
@Value(value = "${openmeetings_url}")
|
|
|
|
|
private static String OPENMEETINGS_URL;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 创建房间并返回房间地址
|
|
|
|
|
* @return
|
|
|
|
|
*/
|
|
|
|
|
public String saveRoom(String userId) {
|
|
|
|
|
public JSONObject saveRoom(String userId) {
|
|
|
|
|
Room room = new Room();
|
|
|
|
|
room.setName("远程协助"+userId);
|
|
|
|
|
room.setDeleted(0);
|
|
|
|
@ -71,53 +76,11 @@ public class RoomServiceImpl extends ServiceImpl<RoomMapper, Room> implements IR
|
|
|
|
|
room.setChatModerated(0);
|
|
|
|
|
roomMapper.insert(room);
|
|
|
|
|
//生成房间地址
|
|
|
|
|
//请求地址
|
|
|
|
|
String soapUrl = "http://www.webxml.com.cn/WebServices/WeatherWebService.asmx?wsdl";
|
|
|
|
|
HashMap<String, Object> map = new HashMap<>();
|
|
|
|
|
map.put("theCityName", "武汉");
|
|
|
|
|
SoapClient soapClient = SoapClient.create(soapUrl)
|
|
|
|
|
//请求方法,命名空间
|
|
|
|
|
.setMethod("web:getWeatherbyCityName", "http://WebXml.com.cn/")
|
|
|
|
|
.setParams(map);
|
|
|
|
|
String sendSoap = soapClient.send(true);
|
|
|
|
|
System.out.println(sendSoap);
|
|
|
|
|
Map<String, String> map1 = new HashMap<String, String>();
|
|
|
|
|
Map<String, String> soapMap = XmlMap(sendSoap, map1);
|
|
|
|
|
System.out.println(JSONObject.toJSONString(soapMap));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
String roomUrl = "";
|
|
|
|
|
return roomUrl;
|
|
|
|
|
String result = WebServiceUtil.send("请求人", room.getId());
|
|
|
|
|
String roomUrl = OPENMEETINGS_URL + JSONObject.parseObject(result).getString("message");
|
|
|
|
|
JSONObject json = new JSONObject();
|
|
|
|
|
json.put("roomUrl", roomUrl);
|
|
|
|
|
json.put("roomId", room.getId());
|
|
|
|
|
return json;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static Map<String, String> XmlMap(String xml, Map<String, String> map) {
|
|
|
|
|
try {
|
|
|
|
|
SAXReader reader = new SAXReader();
|
|
|
|
|
Document doc = reader.read(new StringReader(xml));
|
|
|
|
|
Element root = doc.getRootElement();
|
|
|
|
|
String path = "";
|
|
|
|
|
if (map.containsKey(root.getName().trim())) {
|
|
|
|
|
path = map.get(root.getName().trim());
|
|
|
|
|
map.remove(root.getName().trim());
|
|
|
|
|
}
|
|
|
|
|
for (Iterator i = root.elementIterator(); i.hasNext(); ) {
|
|
|
|
|
Element element = (Element) i.next();
|
|
|
|
|
if (element.isTextOnly()) {
|
|
|
|
|
if (path.length() > 0) {
|
|
|
|
|
map.put(path + element.getName().trim(), element.getTextTrim());
|
|
|
|
|
} else {
|
|
|
|
|
map.put(element.getName().trim(), element.getTextTrim());
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
map.put(element.getName().trim(), path + element.getName().trim() + ".");
|
|
|
|
|
XmlMap(element.asXML(), map);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} catch (Exception e) {
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
}
|
|
|
|
|
return map;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|