HttpClient实现一个项目访问另一个项目的接口

    /**
     * 远程调用接口测试
     */
    @RequestMapping("/jsonTest")
    @ResponseBody
    public Spring doHttpGet(){
        // 需要访问的接口路径
        String url="https://jsonview.com/example.json";
        // 配置请求信息(请求时间)
        RequestConfig rc = RequestConfig.custom().setSocketTimeout(5000).setConnectTimeout(5000).build();
        // 获取使用DefaultHttpClient对象
        CloseableHttpClient httpclient = HttpClients.createDefault();
        // 返回结果
        String result = null;
        if(url!=null){
            try {
                // 创建HttpGet对象,将URL通过构造方法传入HttpGet对象
                HttpGet httpGet=new HttpGet(url);
                // 将配置好请求信息附加到http请求中
                httpGet.setConfig(rc);
                // 执行DefaultHttpClient对象的execute方法发送GET请求,通过CloseableHttpResponse接口的实例,可以获取服务器返回的信息
                CloseableHttpResponse response = httpclient.execute(httpGet);
                try {
                    // 得到返回对象
                    HttpEntity entity = response.getEntity();
                    if(entity!=null){
                        // 获取返回结果
                        result = EntityUtils.toString(entity);

                    }
                } catch (IOException e) {
                    e.printStackTrace();
                }finally {
                    // 关闭到客户端的连接
                    response.close();
                }
            } catch (IOException e) {
                e.printStackTrace();
            }finally {
                try {
                    // 关闭http请求
                    httpclient.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
        //将得到的字符串转换成json对象(请求的本来就是把json格式数据以字符串的格式输出了)
        //JSONObject jsonObject= JSON.parseObject(result);
        //返回json格式
        return jsonObject;
    }

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
ps:主要解决在webservice中,我们想从另外一个项目调用webservice项目接口,也就是跨项目调用接口 这里主要用到了xfire wsdl 废话不说了 直接上东西 1. 首先新建一个项目 2. 在src下创建两个文件: a) 第一个是你想要访问的webservice的接口,比如我想访问接口是 ReleaseService 那就在当前项目创建一个ReleaseService接口(接口中的方法必须和你想要访问的webservice的接口中的方法相同) b) 第二个是你的调用类 3. 导入相应的jar包,这些包不能引用,一定要复制到lib文件夹下面在引用 4. 具体的实现代码 TestWebService方法的代码: package com.isanta.webServiceTest; import java.io.InputStream; import java.net.MalformedURLException; import java.util.Properties; import java.util.Scanner; import org.codehaus.xfire.XFireFactory; import org.codehaus.xfire.client.XFireProxyFactory; import org.codehaus.xfire.service.Service; import org.codehaus.xfire.service.binding.ObjectServiceFactory; public class TestWebService { /** * @param args */ public static void testWebService() throws MalformedURLException, Exception{ // TODO Auto-generated method stub /** *这里是我的参数放在了properties文件中,我在读取里面的参数,这里我们也可以通过方法传参数 *如 : testWebService(String url,String xMlStr)() 那么在调用的时候就可以直接传进来了 *url 是你访问的webservice 的tomcat 的服务器地址 */ Properties pro = new Properties(); InputStream in = null; in = TestWebService.class.getResourceAsStream("/request.properties"); pro.load(in); String url = pro.getProperty("url"); String xMLstr = pro.getProperty("xMLstr"); Service s=new ObjectServiceFactory().create(ReleaseService.class); XFireProxyFactory xf=new XFireProxyFactory(XFireFactory.newInstance().getXFire()); System.out.println("url="+url); try { //这里就是获取webservice的接口的实例对象 ReleaseService seleaseService=(ReleaseService) xf.create(s,url); System.out.println("进入接口----------------->请求报文:"+xMLstr); //这里就是调用你需要的接口的方法 String st=seleaseService.queryReceiptDatas(xMLstr); System.out.print(st); } catch(Exception e) { e.printStackTrace(); } } } 5. 将整个项目打包成jar 6. 将打好的jar包引入到你想要调用的项目中,然后就想 正常的代码一样来调用,如: import java.net.MalformedURLException; import com.isanta.webServiceTest.TestWebService; public class Test { public static void main(String[] args) throws MalformedURLException, Exception { TestWebService.testWebService(); } }
好的,我可以为您提供一个基于SQL Server的服务器项目框架供您参考。这个项目框架使用C#编写,它包含以下几个部分: 1. 数据库访问层: 使用ADO.NET连接到SQL Server数据库,提供对数据的基本操作,例如查询、插入、更新和删除。 2. 业务逻辑层: 包含业务逻辑的实现,例如用户身份验证、权限管理、数据验证等。 3. Web API层: 使用ASP.NET Web API框架,提供RESTful API接口,用于客户端与服务器之间的通信。 4. 客户端: 可以是Web应用程序、桌面应用程序或移动应用程序,使用HTTP协议与服务器进行通信,处理和显示数据。 下面是一个简单的SQL Server服务器项目的示例代码: 1. 数据库访问层: ```csharp public class DataAccess { private SqlConnection conn; private SqlCommand cmd; public DataAccess(string connectionString) { conn = new SqlConnection(connectionString); cmd = new SqlCommand(); cmd.Connection = conn; } public DataSet ExecuteQuery(string sql) { cmd.CommandText = sql; SqlDataAdapter adapter = new SqlDataAdapter(cmd); DataSet ds = new DataSet(); adapter.Fill(ds); return ds; } public int ExecuteNonQuery(string sql) { cmd.CommandText = sql; conn.Open(); int result = cmd.ExecuteNonQuery(); conn.Close(); return result; } } ``` 2. 业务逻辑层: ```csharp public class UserManager { private DataAccess dataAccess; public UserManager(DataAccess dataAccess) { this.dataAccess = dataAccess; } public bool Authenticate(string username, string password) { string sql = "SELECT COUNT(*) FROM Users WHERE Username = '" + username + "' AND Password = '" + password + "'"; int count = (int)dataAccess.ExecuteQuery(sql).Tables[0].Rows[0][0]; return count > 0; } public bool HasPermission(string username, string permission) { string sql = "SELECT COUNT(*) FROM Permissions WHERE Username = '" + username + "' AND Permission = '" + permission + "'"; int count = (int)dataAccess.ExecuteQuery(sql).Tables[0].Rows[0][0]; return count > 0; } public bool CreateUser(string username, string password) { string sql = "INSERT INTO Users (Username, Password) VALUES ('" + username + "', '" + password + "')"; int result = dataAccess.ExecuteNonQuery(sql); return result > 0; } } ``` 3. Web API层: ```csharp public class UserController : ApiController { private UserManager userManager; public UserController() { string connectionString = ConfigurationManager.ConnectionStrings["MyConnectionString"].ConnectionString; DataAccess dataAccess = new DataAccess(connectionString); userManager = new UserManager(dataAccess); } [HttpGet] public HttpResponseMessage Authenticate(string username, string password) { bool result = userManager.Authenticate(username, password); HttpResponseMessage response = Request.CreateResponse(result ? HttpStatusCode.OK : HttpStatusCode.Unauthorized); return response; } [HttpGet] public HttpResponseMessage HasPermission(string username, string permission) { bool result = userManager.HasPermission(username, permission); HttpResponseMessage response = Request.CreateResponse(result ? HttpStatusCode.OK : HttpStatusCode.Forbidden); return response; } [HttpPost] public HttpResponseMessage CreateUser(string username, string password) { bool result = userManager.CreateUser(username, password); HttpResponseMessage response = Request.CreateResponse(result ? HttpStatusCode.Created : HttpStatusCode.BadRequest); return response; } } ``` 4. 客户端: ```csharp public class Program { public static void Main(string[] args) { string baseUrl = "http://localhost:8080/api/User/"; HttpClient client = new HttpClient(); // 认证用户 string username = "admin"; string password = "password"; HttpResponseMessage response = client.GetAsync(baseUrl + "Authenticate?username=" + username + "&password=" + password).Result; if (response.StatusCode == HttpStatusCode.OK) { Console.WriteLine("Authenticated successfully."); } else { Console.WriteLine("Authentication failed."); } // 检查用户权限 string permission = "create-user"; response = client.GetAsync(baseUrl + "HasPermission?username=" + username + "&permission=" + permission).Result; if (response.StatusCode == HttpStatusCode.OK) { Console.WriteLine("User has permission to create user."); } else { Console.WriteLine("User does not have permission to create user."); } // 创建新用户 string newUsername = "newuser"; string newPassword = "newpassword"; var content = new FormUrlEncodedContent(new[] { new KeyValuePair<string, string>("username", newUsername), new KeyValuePair<string, string>("password", newPassword) }); response = client.PostAsync(baseUrl + "CreateUser", content).Result; if (response.StatusCode == HttpStatusCode.Created) { Console.WriteLine("User created successfully."); } else { Console.WriteLine("Failed to create user."); } Console.ReadLine(); } } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值