php中get,post,cookies,session的反斜杠问题

本文探讨了PHP中使用magic_quotes_runtime时对数据的影响,包括如何在数据入库前后进行正确的转义和去除转义处理,以及在不同设置下如何避免数据显示错误。

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

<pre name="code" class="php">magic_quotes_runtime =on时,php在提取数据(包括从get,post,cookies,session,数据库)时就会自动在' " \前加上转义符"\"而当magic_quotes_runtime =off时就没有该功能,而数据入库前通过addslashes()加的转义符在存入数据库时就被自动过滤掉了,所以如果php.ini中magic_quotes_runtime =off时再用stripslashes()去掉“\”就会无法正确显示原来的数据。
数据放入数据库和取出来显示在页面需要注意什么
//addslashes与stripslashes互应函数
入库时
$str=addslashes($str);
$sql="insert into `tab` (`content`) values('$str')";
出库时
$str=stripslashes($str);
显示时
//nl2br与htmlspecialchars是互应函数
$str=htmlspecialchars(nl2br($str)) ;
要改一下才不至于误导人出库时
$str=stripslashes($str);是否stripslashes要看php.ini中magic_quotes_runtime是否为on



是分析我发给你的脚本xinzaixian.py,分析脚本后,写一个命令行的使用示例给我,我需要的是输入接口地址和请求方式还有参数的使用示例。 #!/usr/bin/python3 # coding=utf-8 import time import json import sys import requests from zaixian_cas_login import cas_login, HttpResponseProcessor # 假设两个文件在同一目录下 # 定义标准返回结构 SUCCESS_RES = { 'resCode': 200, 'resTime': 0, 'keyword': 'SUCCESS', 'message': '', 'data': None # 用于存放业务数据 } FAILURE_RES = { 'resCode': 500, 'resTime': 0, 'keyword': 'FAILED', 'message': '', 'error': None # 存放错误信息 } def make_business_request(url, method=None, params=None, data=None, json_data=None, token=None, session_cookies=None): """ 使用已登录的会话和token进行业务请求 :param url: 业务接口URL :param method: 请求方法(可选),自动判断未指定 :param params: URL查询参数 :param data: 表单数据(用于POST/PUT等) :param json_data: JSON数据(用于POST/PUT等) :param token: 登录成功后获取的token :param session_cookies: 登录成功后获取的session cookies :return: 标准化结果字典 """ start_time = time.time() result_template = SUCCESS_RES.copy() # 使用成功模板 try: # 创建会话并设置cookies session = requests.Session() if session_cookies: session.cookies.update(session_cookies) # 设置请求头 headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36', 'Accept': 'application/json,text/plain,text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7', 'Accept-Encoding': 'gzip, deflate, br, zstd', 'Connection': 'keep-alive', 'Cache-Control': 'no-cache', 'Pragma': 'no-cache' } if token: headers['Cookie'] = f'prod-token={token}' # 将token添加到Cookie # 自动判断请求方法(如果未指定) if method is None: method = 'POST' if (data is not None or json_data is not None) else 'GET' else: method = method.upper() # 统一转换为大写 # 准备请求参数 request_kwargs = { 'url': url, 'params': params, 'headers': headers, 'verify': False } # 根据方法类型添加相应参数 if method in ['POST', 'PUT', 'PATCH', 'DELETE']: if json_data is not None: request_kwargs['json'] = json_data headers['Content-Type'] = 'application/json' elif data is not None: request_kwargs['data'] = data # 发送请求 response = session.request(method, **request_kwargs) # 使用HttpResponseProcessor处理响应 processor = HttpResponseProcessor(url, headers=headers) processor.response = response # 手动设置响应对象 processor.raw_content = response.content processor.status_code = response.status_code text_content = processor.decode_content() # 记录响应间 result_template['resTime'] = int((time.time() - start_time) * 1000) # 检查HTTP状态码 if response.status_code != 200: result_template.update(FAILURE_RES) # 转换为失败结构 result_template['resCode'] = response.status_code result_template['message'] = f"业务接口请求失败,状态码: {response.status_code}" result_template['error'] = text_content[:500] # 截取部分错误信息 return result_template # 尝试解析JSON响应 try: json_data = json.loads(text_content) result_template['data'] = json_data except json.JSONDecodeError: result_template['data'] = text_content # 如果不是JSON,则保存文本 result_template['message'] = "业务请求成功" return result_template except Exception as e: result_template.update(FAILURE_RES) # 转换为失败结构 result_template['resTime'] = int((time.time() - start_time) * 1000) result_template['message'] = "业务请求过程中发生异常" result_template['error'] = str(e) return result_template def main(): # 第一步:登录获取token和session username = "jffwbc1" password = "R2pjcHgxMjMhQCM=" # base64编码的密码 token, session_cookies = cas_login(username, password) if not token or not session_cookies: print("登录失败,无法进行业务请求") sys.exit(1) print("登录成功!") print(f"Token: {token}") print(f"Session Cookies: {session_cookies}") # 第二步:使用命令行参数获取请求配置 if len(sys.argv) < 2: print("请提供请求URL作为参数") sys.exit(1) url = sys.argv[1] method = sys.argv[2] if len(sys.argv) > 2 else None params = json.loads(sys.argv[3]) if len(sys.argv) > 3 and sys.argv[3] != 'null' else None data = json.loads(sys.argv[4]) if len(sys.argv) > 4 and sys.argv[4] != 'null' else None json_data = json.loads(sys.argv[5]) if len(sys.argv) > 5 and sys.argv[5] != 'null' else None # 执行请求 result = make_business_request( url=url, method=method, params=params, data=data, json_data=json_data, token=token, session_cookies=session_cookies ) # 打印结果 print("\n业务请求结果:") print(json.dumps(result, indent=2, ensure_ascii=False)) if __name__ == '__main__': main()
最新发布
08-09
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值