thinkphp中对请求封装
请求的封装
//调用
$res = Http::post($this->baseUrl . $url,$params,[CURLOPT_HTTPHEADER => ['Content-Type: application/json','Content-Length: ' . strlen($params),],]);<?php
namespace fast;
/*** 字符串类*/
class Http
{/*** 发送一个POST请求*/public static function post($url, $params = [], $options = []) {$req = self::sendRequest($url, $params, 'POST', $options);return $req['ret'] ? $req['msg'] : '';}/*** 发送一个GET请求*/public static function get($url, $params = [], $options = []) {$req = self::sendRequest($url, $params, 'GET', $options);return $req['ret'] ? $req['msg'] : '';}/*** 发送一个POST JSON请求*/public static function postJson($url, $params = [], $options = []) {is_array($params) && $params = json_encode($params, JSON_UNESCAPED_UNICODE);$req = self::sendRequest($url, $params, 'POST', array_merge_replace([CURLOPT_HTTPHEADER => ['Content-Type: application/json','Content-Length: ' . strlen($params),],], $options));return $req['ret'] ? $req['msg'] : '';}/*** CURL发送Request请求,含POST和REQUEST* @param string $url 请求的链接* @param mixed $params 传递的参数* @param string $method 请求的方法* @param mixed $options CURL的参数* @return array*/public static function sendRequest($url, $params = [], $method = 'POST', $options = []) {$method = strtoupper($method);$protocol = substr($url, 0, 5);if (stripos($url, '/product/collectorUploadImg') !== false || stripos($url, '/assemblers/upload') !== false || stripos($url, '/product/tinymecFileAllow') !== false|| stripos($url, '/refund/uploadFile') !== false || stripos($url, '/invoice/uploadPdfLimitTwoMega') !== false|| stripos($url, '/base/upload/uploadImgLimitForApi') !== false || stripos($url, '/item/seller/itemPublish/publishItemForApi') !== false|| stripos($url, '/product/contractUploadImg') !== false) {//国铁推送文件信息$query_string = $params;} else {$query_string = is_array($params) ? http_build_query($params) : $params;}$ch = curl_init();$defaults = [];if ('GET' == $method) {$geturl = $query_string ? $url . (stripos($url, "?") !== FALSE ? "&" : "?") . $query_string : $url;$defaults[CURLOPT_URL] = $geturl;} else {$defaults[CURLOPT_URL] = $url;if ($method == 'POST') {$defaults[CURLOPT_POST] = 1;} else {$defaults[CURLOPT_CUSTOMREQUEST] = $method;}$defaults[CURLOPT_POSTFIELDS] = $query_string;}$defaults[CURLOPT_HEADER] = FALSE;$defaults[CURLOPT_USERAGENT] = "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.98 Safari/537.36";$defaults[CURLOPT_FOLLOWLOCATION] = TRUE;$defaults[CURLOPT_RETURNTRANSFER] = TRUE;$defaults[CURLOPT_CONNECTTIMEOUT] = 3;$defaults[CURLOPT_TIMEOUT] = 3000;// disable 100-continuecurl_setopt($ch, CURLOPT_HTTPHEADER, array('Expect:'));if ('https' == $protocol) {$defaults[CURLOPT_SSL_VERIFYPEER] = FALSE;$defaults[CURLOPT_SSL_VERIFYHOST] = FALSE;}curl_setopt_array($ch, (array) $options + $defaults);$ret = curl_exec($ch);$err = curl_error($ch);if (FALSE === $ret || !empty($err)) {$errno = curl_errno($ch);$info = curl_getinfo($ch);curl_close($ch);return ['ret'=>FALSE, 'errno'=>$errno, 'msg'=>$err, 'info'=>$info];}curl_close($ch);return ['ret'=>TRUE, 'msg'=>$ret];}/*** 异步发送一个请求* @param string $url 请求的链接* @param mixed $params 请求的参数* @param string $method 请求的方法* @return boolean TRUE*/public static function sendAsyncRequest($url, $params = [], $method = 'POST') {$method = strtoupper($method);$method = $method == 'POST' ? 'POST' : 'GET';//构造传递的参数if (is_array($params)) {$post_params = [];foreach ($params as $k => &$v) {if (is_array($v))$v = implode(',', $v);$post_params[] = $k . '=' . urlencode($v);}$post_string = implode('&', $post_params);} else {$post_string = $params;}$parts = parse_url($url);//构造查询的参数if ($method == 'GET' && $post_string) {$parts['query'] = isset($parts['query']) ? $parts['query'] . '&' . $post_string : $post_string;$post_string = '';}$parts['query'] = isset($parts['query']) && $parts['query'] ? '?' . $parts['query'] : '';//发送socket请求,获得连接句柄$fp = fsockopen($parts['host'], isset($parts['port']) ? $parts['port'] : 80, $errno, $errstr, 3);if (!$fp)return FALSE;//设置超时时间stream_set_timeout($fp, 3);$out = "{$method} {$parts['path']}{$parts['query']} HTTP/1.1\r\n";$out.= "Host: {$parts['host']}\r\n";$out.= "Content-Type: application/x-www-form-urlencoded\r\n";$out.= "Content-Length: " . strlen($post_string) . "\r\n";$out.= "Connection: Close\r\n\r\n";if ($post_string !== '')$out .= $post_string;fwrite($fp, $out);//不用关心服务器返回结果//echo fread($fp, 1024);fclose($fp);return TRUE;}/*** 发送文件到客户端* @param string $file* @param bool $delaftersend* @param bool $exitaftersend*/public static function sendToBrowser($file, $delaftersend = true, $exitaftersend = true) {if (file_exists($file) && is_readable($file)) {header('Content-Description: File Transfer');header('Content-Type: application/octet-stream');header('Content-Disposition: attachment;filename = ' . basename($file));header('Content-Transfer-Encoding: binary');header('Expires: 0');header('Cache-Control: must-revalidate, post-check = 0, pre-check = 0');header('Pragma: public');header('Content-Length: ' . filesize($file));ob_clean();flush();readfile($file);if ($delaftersend) {unlink($file);}if ($exitaftersend) {exit;}}}}
相关文章:
thinkphp中对请求封装
请求的封装 //调用 $res Http::post($this->baseUrl . $url,$params,[CURLOPT_HTTPHEADER > [Content-Type: application/json,Content-Length: . strlen($params),],]);<?php namespace fast; /*** 字符串类*/ class Http {/*** 发送一个POST请求*/public static …...
leetcode hot100【LeetCode 215.数组中的第K个最大元素】java实现
LeetCode 215.数组中的第K个最大元素 题目描述 给定一个整数数组 nums 和一个整数 k,请返回数组中第 k 个最大的元素。 请注意,要求排名是从大到小的,因此第 k 个最大元素是排序后的第 k 个元素。你需要设计一个高效的算法来解决这个问题。…...
簡單易懂:如何在Windows系統中修改IP地址?
無論是為了連接到一個新的網路,還是為了解決網路連接問題,修改IP地址都是一個常見的操作。本文將詳細介紹如何在Windows系統中修改IP地址,包括靜態IP地址的設置和動態IP地址的獲取。 IP地址是什麼? IP地址是互聯網協議地址的簡稱…...
Python中的23种设计模式:详细分类与总结
设计模式是解决特定问题的通用方法,分为创建型模式、结构型模式和行为型模式三大类。以下是对每种模式的详细介绍,包括其核心思想、应用场景和优缺点。 一、创建型模式(Creational Patterns) 创建型模式关注对象的创建࿰…...
日历使用及汉化——fullcalendar前端
官网 FullCalendar - JavaScript Event Calendar 引入项目 <link hrefhttps://cdnjs.cloudflare.com/ajax/libs/fullcalendar/5.10.1/main.min.css relstylesheet /><script srchttps://cdnjs.cloudflare.com/ajax/libs/fullcalendar/5.10.1/main.min.js></sc…...
视频截断,使用 FFmpeg
使用 FFmpeg 截取视频并去掉 5 分 49 秒后的内容,可以使用以下命令: ffmpeg -i input.mp4 -t 00:05:49 -c:v libx264 -crf 23 -preset medium -c:a aac -b:a 192k output.mp4-i input.mp4: 指定输入视频文件 input.mp4。 -t 00:05:49&#x…...
使用系统内NCCL环境重新编译Pytorch
intro: 费了老大劲,来重新编译pytorch,中间报了无数错误。原生的编译好的pytorch是直接用的其自带NCCL库,并且从外部是不能进行插桩的,因为根本找不到libnccl.so文件。下面记录下重新编译pytorch的过程。指定USE_SYSTEM_NCCL1。这…...
1. Klipper从安装到运行
本文记录Klipper固件从安装,配置到运行的详细过程 Klipper是3D打印机固件之一,它通常运行在linux系统(常使用Debian,其它的linux版本也可以)上,因此需要一个能运行Linux系统的硬件,比如电脑&am…...
docker 卸载与安装
卸载 查询之前安装的docker, 没有查到则不用卸载删除 yum list installed | grep docker 卸载安装包 yum remove docker-* -y 删除镜像、容器、默认挂载卷 rm -rf /var/lib/docker 安装 -ce 安装稳定版本 -y 当安装过程提示选择全部为 "yes" yum install d…...
跨部门文件共享安全:平衡协作与风险的关键策略
在现代企业中,跨部门协作已成为推动业务发展的关键因素。然而,随着信息的自由流动和共享,文件安全风险也随之增加。如何在促进跨部门协作的同时,确保文件共享的安全性,成为了一个亟待解决的问题。 一、明确文件分类与…...
基于单片机的智慧小区人脸识别门禁系统
本设计基于单片机的智慧小区人脸识别门禁系统。由STM32F103C8T6单片机核心板、显示模块、摄像头模块、舵机模块、按键模块和电源模块组成。可以通过摄像头模块对进入人员人脸数据进行采集,识别成功后,舵机模块动作,模拟门禁打开,门…...
【es6】原生js在页面上画矩形及删除的实现方法
画一个矩形,可以选中高亮,删除自己效果的实现,后期会丰富下细节,拖动及拖动调整矩形大小 实现效果 代码实现 class Draw {constructor() {this.x 0this.y 0this.disX 0this.disY 0this.startX 0this.startY 0this.mouseDo…...
【git实践】分享一个适用于敏捷开发的分支管理策略
文章目录 1. 背景2. 分支管理实践2.1. 敏捷开发中分支管理面临的问题2.2. 分支管理策略2.3. 还需要注意的一些问题 3.总结 1. 背景 在实际的开发工作中,我们往往会面临多任务并行研发,多个环境管理的情况,这种情况下,一个合适的分…...
Redis与MySQL如何保证数据一致性
Redis与MySQL如何保证数据一致性 简单来说 该场景主要发生在读写并发进行时,才会发生数据不一致。 主要流程就是要么先操作缓存,要么先操作Redis,操作也分修改和删除。 一般修改要执行一系列业务代码,所以一般直接删除成本较低…...
基于微信小程序的教室预约系统+LW示例参考
1.项目介绍 功能模块:管理员(学生管理、教师管理、申请管理、设备管理、报修管理等)、普通用户/学生(注册登录、申请预约、退订、报修等)技术选型:SSM、JSP、uniapp等测试环境:idea2024&#x…...
Linux 安装 Git 服务器
一、安装 Git 1. 在 CentOS/RHEL 中使用以下命令: sudo yum update -y # 或者 sudo dnf update -y (在较新的系统中) sudo yum install git -y验证安装:git --version 2. 配置 Git 用户 git config --global user.name "Your Name" git co…...
总结:Yarn资源管理
一、介绍 本文梳理下Yarn的资源分配计算逻辑。 二、配置 - 资源限制 1、配置NodeManager可分配的资源池的总量 <property><name>yarn.nodemanager.resource.memory-mb</name><value>4096</value> </property> 作用对象:节点管理器(No…...
Python学习34天
import random class Game: peo0 rob0 # # def __init__(self,peo,rob): # self.peopeo # self.robrob def Play(self): """ 石头剪刀布游戏,0代表石头,1代见到,2代表石头 …...
深入浅出 WebSocket:构建实时数据大屏的高级实践
简介 请参考下方,学习入门操作 基于 Flask 和 Socket.IO 的 WebSocket 实时数据更新实现 在当今数字化时代,实时性是衡量互联网应用的重要指标之一。无论是股票交易、在线游戏,还是实时监控大屏,WebSocket 已成为实现高效、双向…...
三开关VUE组件
一、使用效果 <template><QqThreeSwitch v-model"value" /><!-- <SqThreeSwitch v-model"value" :options"[test1, test2, test3]"><template #left-action><div style"display: flex"><IconMoon…...
uniapp 对接腾讯云IM群组成员管理(增删改查)
UniApp 实战:腾讯云IM群组成员管理(增删改查) 一、前言 在社交类App开发中,群组成员管理是核心功能之一。本文将基于UniApp框架,结合腾讯云IM SDK,详细讲解如何实现群组成员的增删改查全流程。 权限校验…...
【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型
摘要 拍照搜题系统采用“三层管道(多模态 OCR → 语义检索 → 答案渲染)、两级检索(倒排 BM25 向量 HNSW)并以大语言模型兜底”的整体框架: 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后,分别用…...
Swift 协议扩展精进之路:解决 CoreData 托管实体子类的类型不匹配问题(下)
概述 在 Swift 开发语言中,各位秃头小码农们可以充分利用语法本身所带来的便利去劈荆斩棘。我们还可以恣意利用泛型、协议关联类型和协议扩展来进一步简化和优化我们复杂的代码需求。 不过,在涉及到多个子类派生于基类进行多态模拟的场景下,…...
深入浅出:JavaScript 中的 `window.crypto.getRandomValues()` 方法
深入浅出:JavaScript 中的 window.crypto.getRandomValues() 方法 在现代 Web 开发中,随机数的生成看似简单,却隐藏着许多玄机。无论是生成密码、加密密钥,还是创建安全令牌,随机数的质量直接关系到系统的安全性。Jav…...
visual studio 2022更改主题为深色
visual studio 2022更改主题为深色 点击visual studio 上方的 工具-> 选项 在选项窗口中,选择 环境 -> 常规 ,将其中的颜色主题改成深色 点击确定,更改完成...
令牌桶 滑动窗口->限流 分布式信号量->限并发的原理 lua脚本分析介绍
文章目录 前言限流限制并发的实际理解限流令牌桶代码实现结果分析令牌桶lua的模拟实现原理总结: 滑动窗口代码实现结果分析lua脚本原理解析 限并发分布式信号量代码实现结果分析lua脚本实现原理 双注解去实现限流 并发结果分析: 实际业务去理解体会统一注…...
【python异步多线程】异步多线程爬虫代码示例
claude生成的python多线程、异步代码示例,模拟20个网页的爬取,每个网页假设要0.5-2秒完成。 代码 Python多线程爬虫教程 核心概念 多线程:允许程序同时执行多个任务,提高IO密集型任务(如网络请求)的效率…...
rnn判断string中第一次出现a的下标
# coding:utf8 import torch import torch.nn as nn import numpy as np import random import json""" 基于pytorch的网络编写 实现一个RNN网络完成多分类任务 判断字符 a 第一次出现在字符串中的位置 """class TorchModel(nn.Module):def __in…...
Java毕业设计:WML信息查询与后端信息发布系统开发
JAVAWML信息查询与后端信息发布系统实现 一、系统概述 本系统基于Java和WML(无线标记语言)技术开发,实现了移动设备上的信息查询与后端信息发布功能。系统采用B/S架构,服务器端使用Java Servlet处理请求,数据库采用MySQL存储信息࿰…...
GruntJS-前端自动化任务运行器从入门到实战
Grunt 完全指南:从入门到实战 一、Grunt 是什么? Grunt是一个基于 Node.js 的前端自动化任务运行器,主要用于自动化执行项目开发中重复性高的任务,例如文件压缩、代码编译、语法检查、单元测试、文件合并等。通过配置简洁的任务…...
