【Django】URL中传递中文时出乱码的问题

开发环境:Ubuntu16.04+Django 1.11.9+Python2.7

在开发中,在做查找某些信息这个功能的时候,遇到的一个问题。需要在URL中传递查找的关键字,当关键字为中文的时候,并不友好.

当输入关键字为中文(这里我输入的是’第一次’)的时候,接收到参数是这样的
%E7%AC%AC%E4%B8%80%E6%AC%A1
这样格式的是经过urlencode后的中文,既然这样就需要进行url解码.

import urllib
c='%E7%AC%AC%E4%B8%80%E6%AC%A1'
e=urllib.unquote(c)
c='1'
f=urllib.unquote(c)
print e 	#输出结果: 第一次
print f 	# 输出结果: 1

上面的代码是在Windows下Pycharm里测试输出的,结果符合预期.

在开发代码中写入后,使用postman进行测试的时候,是可以的.但当和前端页面进行联合调试的时候,就出现了问题.

import urllib
def select_seller(request,keyword):
    logging.debug(keyword)       #logging.debug 接收到的参数%E7%AC%AC%E4%B8%80%E6%AC%A1
    keyword = urllib.unquote(keyword)
    logging.debug(keyword)       # 解码后:第ä¸<80>次

接收到的参数,解码后居然是‘第ä¸<80>次’这样的࿰

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django,如果前端页面显示的中文出现乱码,可能是由于字符编码不一致导致的。下面是一些可能导致中文乱码的原因和解决方法: 1. 数据库字符编码问题:确保数据库的字符编码与Django项目的字符编码一致。可以在Django的settings.py文件设置DATABASES选项的'OPTIONS'参数,指定字符编码。 2. 模板文件编码问题:确保模板文件的编码与Django项目的字符编码一致。可以在模板文件的开头添加以下注释来指定编码格式: ``` {% autoescape off %} <!DOCTYPE html> <!-- coding: utf-8 --> <html> ... </html> {% endautoescape %} ``` 3. 响应头设置编码:在视图函数,可以通过设置响应头的Content-Type字段来指定字符编码。例如: ``` from django.http import HttpResponse def my_view(request): response = HttpResponse(content_type='text/html; charset=utf-8') response.write("中文内容") return response ``` 4. 字符串编码转换:如果从数据库或其他地方获取的字符串编码与前端页面不一致,可以使用Python的字符串编码转换函数进行转换。例如,使用`str.encode()`将字符串转换为指定编码,使用`str.decode()`将字符串从指定编码转换为Unicode。 5. HTML元标记设置编码:在HTML页面的<head>标签,可以添加以下元标记来指定字符编码: ``` <meta charset="utf-8"> ``` 6. 使用Unicode字符串:在Django,推荐使用Unicode字符串来处理中文字符,以避免编码问题。 希望以上解决方法能够帮助您解决Django前端中文乱码问题

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值