JavaScript、C# URL编码、解码总结

JavaScript、C# URL编码、解码总结

在进行URL传输时,为了防止特殊字符导致的错误,需要对URL进行编码。JavaScript和C#都提供了URL编码、解码的方法。

JavaScript URL编码、解码

在JavaScript中,可以使用encodeURIencodeURIComponent对URL进行编码,使用decodeURIdecodeURIComponent对URL进行解码。

encodeURI编码

encodeURI可以用来对整个URL进行编码,但只会对URI中的特殊字符进行编码,保留一些特殊字符,如;,/?:@&=+$#等。

const url = "https://www.example.com/search?q=JavaScript编码";
const encodedUrl = encodeURI(url);
console.log(encodedUrl); // https://www.example.com/search?q=JavaScript%E7%BC%96%E7%A0%81

encodeURIComponent编码

encodeURIComponent则可以用来编码URI中的所有特殊字符,包括;,/?:@&=+$#等。

const url = "https://www.example.com/search?q=JavaScript编码";
const encodedUrl = encodeURIComponent(url);
console.log(encodedUrl); // https%3A%2F%2Fwww.example.com%2Fsearch%3Fq%3DJavaScript%E7%BC%96%E7%A0%81

decodeURI解码

decodeURI可以用来对整个URL进行解码,与encodeURI对应。

const encodedUrl = "https://www.example.com/search?q=JavaScript%E7%BC%96%E7%A0%81";
const url = decodeURI(encodedUrl);
console.log(url); // https://www.example.com/search?q=JavaScript编码

decodeURIComponent解码

decodeURIComponent则可以用来解码URI中的所有特殊字符。

const encodedUrl = "https%3A%2F%2Fwww.example.com%2Fsearch%3Fq%3DJavaScript%E7%BC%96%E7%A0%81";
const url = decodeURIComponent(encodedUrl);
console.log(url); // https://www.example.com/search?q=JavaScript编码

C# URL编码、解码

在C#中,可以使用HttpUtility.UrlEncodeHttpUtility.UrlDecode对URL进行编码、解码。

HttpUtility.UrlEncode编码

HttpUtility.UrlEncode可以用来对整个URL进行编码,会对所有特殊字符进行编码,包括;,/?:@&=+$#等。

string url = "https://www.example.com/search?q=JavaScript编码";
string encodedUrl = HttpUtility.UrlEncode(url);
Console.WriteLine(encodedUrl); // https%3a%2f%2fwww.example.com%2fsearch%3fq%3dJavaScript%e7%bc%96%e7%a0%81

HttpUtility.UrlDecode解码

HttpUtility.UrlDecode可以用来对整个URL进行解码,与HttpUtility.UrlEncode对应。

string encodedUrl = "https%3a%2f%2fwww.example.com%2fsearch%3fq%3dJavaScript%e7%bc%96%e7%a0%81";
string url = HttpUtility.UrlDecode(encodedUrl);
Console.WriteLine(url); // https://www.example.com/search?q=JavaScript编码

示例

在一个网页中,用户可以输入一个URL进行页面跳转。为了防止输入的URL中包含特殊字符而导致跳转错误,我们可以使用JavaScript的encodeURIComponent对URL进行编码,然后通过POST请求将编码后的URL发送到后端。

<form action="/redirect" method="POST">
  <label for="url-input">请输入跳转的URL:</label>
  <input type="text" name="url" id="url-input">
  <button type="submit">跳转</button>
</form>

<script>
  const urlInput = document.querySelector('#url-input');

  document.querySelector('form').addEventListener('submit', (event) => {
    event.preventDefault(); // 阻止表单默认提交行为
    const encodedUrl = encodeURIComponent(urlInput.value);
    fetch('/redirect', {
      method: 'POST',
      body: JSON.stringify({
        url: encodedUrl
      }),
      headers: {
        'Content-Type': 'application/json'
      }
    })
      .then(response => response.json())
      .then(data => {
        if (data.success) {
          window.location.href = data.redirectUrl;
        } else {
          alert('跳转失败');
        }
      });
  });
</script>

后端代码(使用C#)可以先获取POST请求中的编码后的URL,然后通过HttpUtility.UrlDecode解码,最后进行跳转。

public ActionResult Redirect()
{
  string encodedUrl = Request.Form["url"];
  string decodedUrl = HttpUtility.UrlDecode(encodedUrl);
  return Redirect(decodedUrl);
}

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JavaScript、C# URL编码、解码总结 - Python技术站

(0)
上一篇 2023年5月20日
下一篇 2023年5月20日

相关文章

  • 本地存储localStorage用法详解

    本地存储localStorage用法详解 什么是本地存储localStorage 本地存储localStorage是HTML5中提供的一种新的在客户端存储数据的机制,与cookie相比,localStorage有以下优点: 存储容量更大:cookie一般只能存储4KB左右的数据,而localStorage可以存储更大数据(5MB或以上)。 可以存储复杂的数据…

    JavaScript 2023年6月11日
    00
  • jQuery ajax(复习)—Baidu ajax request分离版

    下面是 “jQuery ajax(复习)—Baidu ajax request分离版”的完整攻略。 简介 本篇攻略主要介绍如何使用jQuery发起Ajax请求,以及如何使用Baidu Ajax Request分离版优化你的Ajax请求。 Ajax基础 什么是Ajax? Ajax全称是 Asynchronous JavaScript and XML(异步的 J…

    JavaScript 2023年6月11日
    00
  • javascript实现获取字符串hash值

    获取字符串的哈希值实际上是将字符串转换为一个数字,这个数字唯一地代表了该字符串。JavaScript中可以使用哈希算法来获取字符串的哈希值,下面是获取字符串哈希值的完整攻略。 步骤1:选定哈希函数 JavaScript中常用的字符串哈希函数有很多,比如BKDRHash、APHash、JSHash等。这里以BKDRHash为例,其实现代码如下: functio…

    JavaScript 2023年5月28日
    00
  • js中arguments对象的深入理解

    深入理解JavaScript中的Arguments对象 在JavaScript中,每个函数在被调用的时候都会自动获取一个名为“arguments”的对象。这个对象中包含了该函数被传入的所有参数,并且可以在函数内部进行访问和操作。 Arguments对象简介 Arguments对象是什么? Arguments对象是一个类数组对象,它包含了当前函数被调用时所传入…

    JavaScript 2023年5月27日
    00
  • JS中cookie的使用及缺点讲解

    什么是cookie Cookie是存储在客户端浏览器中的小数据片段,它会在HTTP请求和服务器响应之间传递数据。Cookie通常用于记录用户的登录状态、页面访问记录、用户偏好等信息。 JS中如何使用cookie 1. 设置cookie 要设置Cookie,可以使用document.cookie属性。例如: document.cookie = "us…

    JavaScript 2023年5月19日
    00
  • JavaScript中各种引用类型的常用操作方法小结

    让我来详细讲解一下“JavaScript中各种引用类型的常用操作方法小结”。 引用类型的定义 引用类型指的是一类对象的实例,这些实例由自己定义的构造函数创建。每个引用类型都提供了可以访问它的属性和方法。JavaScript中常见的引用类型有Object、Array、Date、RegExp等等。 Object类型的操作方法 Object类型是所有引用类型中最基…

    JavaScript 2023年5月19日
    00
  • JavaScript的Number对象的toString()方法

    当我们使用JavaScript编写程序的时候,难免会涉及到数字类型的数据操作。Number对象是JavaScript的内置对象之一,它表示数字(包括整数和浮点数)。在实际开发中,我们经常需要将数字类型的数据转化为字符串类型的数据,以便在用户界面中展示或者将数据发送给后端服务器,这时候就可以使用Number对象的toString()方法。 语法 num.toS…

    JavaScript 2023年6月10日
    00
  • laydate.js日期时间选择插件

    “laydate.js日期时间选择插件”是一个常用的JavaScript插件,它可以方便地帮助用户在网页上进行日期和时间的选择。 以下是关于怎样在网页上使用”laydate.js日期时间选择插件”的详细攻略: 安装 在使用”laydate.js日期时间选择插件”之前,需要先将它安装到网页中。有两种方式可以安装该插件: 通过CDN引入。使用该方式只需引入以下代…

    JavaScript 2023年5月27日
    00
合作推广
合作推广
分享本页
返回顶部