带token的get和post方法

本文介绍了使用GET和POST方法进行数据传输的具体实现方式,并详细解释了如何通过这两种方法发送和接收数据。其中包括了设置HTTP请求头部信息、指定请求方法、处理响应数据等关键步骤。

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

GET和POST传值失败,多半是传输的字符串和URL的事

 1 public static string ExcuteGetToken(string serviceUrl, string ReqInfo, string token)
 2 {
 3     using (null)
 4     {
 5         ServicePointManager.ServerCertificateValidationCallback += ValidateServerCertificate;
 6         ServicePointManager.SecurityProtocol = SecurityProtocolType.Ssl3;
 7         ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls;
 8         HttpWebRequest request = (HttpWebRequest)WebRequest.Create(serviceUrl);
 9         request.CookieContainer = new CookieContainer();
10         request.Headers.Add("userName", "abc");  //设置信息头用户名
11         request.Headers.Add("password", "123456"); //设置信息头密码
12         request.Headers.Add("Token", token);
13         request.KeepAlive = true;
14         request.Method = "GET";
15         request.ContentType = "application/x-www-form-urlencoded";
16         //添加发送数据
17         Encoding encoding = Encoding.GetEncoding("utf-8");
18         if (!ReqInfo.Equals(""))
19         {
20             ReqInfo = "request=" + ReqInfo;
21             byte[] postData = encoding.GetBytes(ReqInfo);
22             request.ContentLength = postData.Length;
23             Stream requestStream = request.GetRequestStream();
24             requestStream.Write(postData, 0, postData.Length);
25         }
26         HttpWebResponse response = (HttpWebResponse)request.GetResponse();
27         //获取返回数据
28         Stream responseStream = response.GetResponseStream();
29         if (responseStream == null) return "";
30         StreamReader streamReader = new StreamReader(responseStream, encoding);
31         string retString = streamReader.ReadToEnd();
32         streamReader.Close();
33         responseStream.Close();
34         return retString;
35     }
36 }        

post方法

public static string ExcutePostToken(string serviceUrl, string ReqInfo,string token)
{
    using (null)
    {
        ServicePointManager.ServerCertificateValidationCallback += ValidateServerCertificate;
        ServicePointManager.SecurityProtocol = SecurityProtocolType.Ssl3;
        ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls;
        HttpWebRequest request = (HttpWebRequest)WebRequest.Create(serviceUrl);
        request.CookieContainer = new CookieContainer();
        request.Headers.Add("userName", "abc");  //设置信息头用户名
        request.Headers.Add("password", "123456"); //设置信息头密码
        request.Headers.Add("token", token);
        request.KeepAlive = true;
        request.Method = "POST";
        request.ContentType = "application/json";
        //添加发送数据
        if (!ReqInfo.Equals(""))
        {
            Encoding encoding = Encoding.GetEncoding("utf-8");
            byte[] postData = encoding.GetBytes(ReqInfo);
            request.ContentLength = postData.Length;
            Stream requestStream = request.GetRequestStream();
            requestStream.Write(postData, 0, postData.Length);
        }
        HttpWebResponse response = (HttpWebResponse)request.GetResponse();
        //获取返回数据
        Stream responseStream = response.GetResponseStream();
        if (responseStream == null) return "";
        StreamReader streamReader = new StreamReader(responseStream, Encoding.GetEncoding("utf-8"));
        string retString = streamReader.ReadToEnd();
        streamReader.Close();
        responseStream.Close();
        return retString;
    }
}

private static bool ValidateServerCertificate(object sender, X509Certificate certificate, X509Chain chain, SslPolicyErrors sslPolicyErrors)
{
    return true;
}

 

转载于:https://www.cnblogs.com/Lvkang/p/9633379.html

### 封装 Axios GET POST 请求 #### 获取当前组件实例 在 Vue3 中,`setup` 函数内无法通过 `this` 访问组件实例。为了获取当前组件实例,可以使用 `getCurrentInstance()` 方法[^1]。 ```javascript import { getCurrentInstance } from 'vue'; const instance = getCurrentInstance(); console.log(instance); ``` #### 创建 Axios 实例 创建一个独立的 JavaScript 文件来集中管理所有的 HTTP 请求逻辑,这有助于维护扩展代码[^2]。 ```javascript // src/api/index.js import axios from 'axios'; import { ElMessage } from "element-plus"; const service = axios.create({ baseURL: import.meta.env.VITE_APP_BASE_API, // API base_url timeout: 5000 // request timeout }); service.interceptors.request.use( config => { const token = localStorage.getItem('token'); if (token) { config.headers['Authorization'] = 'Bearer ' + token; } return config; }, error => Promise.reject(error) ); service.interceptors.response.use( response => response.data, error => { let message = ''; switch (error.response.status) { case 401: message = '未授权,请登录'; break; case 403: message = '拒绝访问'; break; case 404: message = '请求地址错误'; break; default: message = '连接服务器失败'; } ElMessage.error(message); return Promise.reject(error); } ); export function get(url, params = {}) { return new Promise((resolve, reject) => { service.get(url, {params}).then(response => resolve(response)).catch(error => reject(error)); }); } export function post(url, data = {}, contentType = 'json') { return new Promise((resolve, reject) => { let config = {}; if(contentType === 'form'){ config.headers = {'Content-Type': 'application/x-www-form-urlencoded'}; Object.keys(data).forEach(key => { if(Array.isArray(data[key])){ data[key] = data[key].join(','); } }); } service.post(url, data, config).then(response => resolve(response)).catch(error => reject(error)); }); } ``` 此文件定义了一个全局可用的服务对象,并配置了拦截器用于处理请求前后的操作以及错误捕获。对于不同的 Content-Type 类型做了区分对待,特别是当发送的数据为表单格式时进行了特殊处理[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值