有道ai写作,突破免费限制,无限制使用
预览效果

- 文末提供源码包及apk下载地址
有道ai写作python版
import hashlib
import time
import json
import ssl
import base64
import uuidfrom urllib.parse import quote
import requests
from requests_toolbelt.multipart.encoder import MultipartEncoder
from Crypto.Cipher import AES
from Crypto.Util.Padding import pad, unpad
from sseclient import SSEClient# 生成唯一的用户id
yduuid=str(uuid.uuid4()).replace('-','')session = requests.session()
lastModified = requests.get('https://fanyi.youdao.com/index.html').headers['last-Modified']
_nlmf = int(time.mktime(time.strptime(lastModified, "%a, %d %b %Y %H:%M:%S GMT")))
session.headers = {'Referer': 'https://fanyi.youdao.com/','User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/111.0.0.0 Safari/537.36',
}
session.get(f'https://rlogs.youdao.com/rlog.php?_npid=fanyiweb&_ncat=pageview&_ncoo=935962676.0432019&_nssn=NULL&_nver=1.2.0&_ntms={time.time()}&_nref=&_nurl=https%3A%2F%2Ffanyi.youdao.com%2Findex.html%23%2F&_nres=1920x1080&_nlmf={_nlmf}&_njve=0&_nchr=utf-8&_nfrg=%2F&/=NULL&screen=1920*1080')# 获取md5加密结果
def get_md5(s,is_hex=True):md5=hashlib.md5()md5.update(s.encode())if is_hex:return md5.hexdigest()return md5.digest()# AES-128-CBC解密
def decrypt(encrypted_data, key, iv):cipher = AES.new(key, AES.MODE_CBC, iv)decrypted_data = cipher.decrypt(base64.b64decode(encrypted_data))return decrypted_data.decode('utf-8')def get_token_and_key():params = {'product': 'webdict', 'appVersion': '1.0', 'client': 'web', 'mid': '1', 'vendor': 'web','screen': '1', 'model': '1', 'imei': '1','network': 'wired', 'keyfrom': 'webdict','keyid': 'ai-write','mysticTime': str(int(time.time()*1000)),'yduuid': yduuid,}# 参数排序sorted_params = sorted(params.items(), key=lambda x: x[0])sorted_params.append(("key","xuiC95RuooxC8Q51UJtdod1plLUhdAmt"))encoded_params = '&'.join([f"{key}={value}" for key, value in sorted_params])print("encoded_params:::::"+encoded_params)# 获取sign签名sign=get_md5(encoded_params)params.update({"sign":sign})params.update({"pointParam":"appVersion,client,imei,keyfrom,keyid,mid,model,mysticTime,network,product,screen,vendor,yduuid,key"})response = session.get('https://luna-ai.youdao.com/write/ai/web/ktf', params=params, verify=False)print(response.text)#============解密数据===============================e=response.text.replace("-","+").replace("_","/")key=get_md5("IIS0fzL@zGv1^zO2%NcZiTcM=98WYxdun$CJE1KUKFfEhz&zpEC0fdXfvGqy*N!r",is_hex=False)iv=get_md5("kG_oSxAXx#xjbiOKAkf9915Ko-XclOBP-GSgfo6E9ZB%9WvgcY6Y7dmje!+m5g#d",is_hex=False)s=decrypt(e,key,iv).replace('\x02', '')print("解密数据::::"+s)decode_data=json.loads(json.loads(s))return decode_datadef get_result(query):decode_data=get_token_and_key()params = {'product': 'webdict', 'appVersion': '1.0', 'client': 'web', 'mid': '1', 'vendor': 'web','screen': '1', 'model': '1', 'imei': '1','network': 'wired', 'keyfrom': 'webdict','keyid': 'ai-write-web','mysticTime': str(int(time.time()*1000)),'yduuid': yduuid,'functionId':'1','query':quote(query),'userCustomize':quote(query),'token':decode_data["token"]}# 参数排序sorted_params = sorted(params.items(), key=lambda x: x[0])sorted_params.append(("key",decode_data['sk']))encoded_params = '&'.join([f"{key}={value}" for key, value in sorted_params])print("encoded_params:::::"+encoded_params)# 获取签名字符串sign=get_md5(encoded_params)params.update({"sign":sign})print("签名字符串:"+sign)params.update({"pointParam":"appVersion,client,functionId,imei,keyfrom,keyid,mid,model,mysticTime,network,product,query,screen,token,userCustomize,vendor,yduuid,key"})# 数据为multipart/form-data格式multipart_data = MultipartEncoder(fields=params)# 修改请求头中的Content-Typesession.headers['Content-Type']= multipart_data.content_type# 发送请求response = session.post('https://luna-ai.youdao.com/write/ai/template/sse', data=multipart_data, stream=True,verify=False)# 处理SSE流数据client=SSEClient(response)for event in client.events():# 判断事件类型if event.event=='message':# 不换行输出print(json.loads(event.data)['content'],end='')if __name__=='__main__':keyword=input('请输入关键词:')get_result(keyword)
有道ai写作lua版
使用
Aide lua打包为apk
- 主要lua代码
require "import"
--import "androidx"
--import "androidx.appcompat.app.*"
--import "androidx.appcompat.view.*"
--import "androidx.appcompat.widget.*"
--import "android.app.*"
import "android.os.*"
import "android.widget.*"
import "android.view.*"
import "androidx.coordinatorlayout.widget.CoordinatorLayout"local layout={CoordinatorLayout;layout_height="fill";layout_width="match_parent";{LinearLayout;layout_width="match_parent";orientation="vertical";layout_height="match_parent";{LinearLayout;layout_width="match_parent";orientation="horizontal";layout_height="wrap_content";{EditText;layout_marginTop="10";id="inputText";hint="请输入关键词";layout_weight=19;layout_marginLeft="5";};{Button;layout_marginTop="10";id="translateBtn";text="ai写作";layout_weight=1;layout_marginRight="5";};};{LinearLayout;layout_width="fill";layout_height="fill";{ScrollView;layout_width="fill";id="1";layout_height="fill";{TextView;layout_margin="10";layout_width="fill";id="resultView";layout_height="wrap_content";};};};};
};--ui结束activity.setContentView(loadlayout(layout))-- 生成时间戳
function getTimestamp()local Date = luajava.bindClass "java.util.Date"return Date().getTime()
end-- 字符串url编码
function urlEncode(s)-- url编码local s = string.gsub(s, "([^%w%.%- ])", function(c) return string.format("%%%02X", string.byte(c)) end)-- 逗号不编码return s:gsub(" ", "+"):gsub("%%2C",","):gsub("%%25","%%")
end-- 字符串序列化
function tableToStr(tbl,sep)local str = ''local sep= sep or '&'for key, value in pairs(tbl) dostr = str .. key .. '=' .. urlEncode(value) .. sependreturn string.sub(str, 1, -2)
end-- 拼接排序后的表为字符串
function tableToStr1(tbl)local str = ''for key, value in ipairs(tbl) dostr = str .. value[1] .. '=' .. urlEncode(value[2]) .. '&'endreturn string.sub(str, 1, -2)
end-- md5加密
function md5Encrypt(data,isHex)local MessageDigest = luajava.bindClass "java.security.MessageDigest"local md = MessageDigest.getInstance("MD5")local bytes = md.digest(String(data).getBytes())local isHex= (isHex==nil) and true or falseif isHex ==false thenreturn bytesendlocal result = ""for i = 0, #bytes - 1 dolocal temp = string.format("%02x", (bytes[i] & 0xff))result = result .. tempendreturn result
end-- AES解密
function decrypt(encryptStr, key, iv)local String = luajava.bindClass "java.lang.String"local SecretKeySpec = luajava.bindClass "javax.crypto.spec.SecretKeySpec"local IvParameterSpec = luajava.bindClass "javax.crypto.spec.IvParameterSpec"local Cipher = luajava.bindClass "javax.crypto.Cipher"local Base64 = luajava.bindClass "android.util.Base64"local algorithm = "AES"local mode = "AES/CBC/PKCS5Padding"local raw=SecretKeySpec(key,algorithm)local ivBytes = IvParameterSpec(iv)local cipher = Cipher.getInstance(mode)cipher.init(Cipher.DECRYPT_MODE, raw, ivBytes)local encode_content = Base64.decode(encryptStr, Base64.DEFAULT)local byte_content = cipher.doFinal(encode_content)return String(byte_content, "utf-8")
end-- 公共请求参数定义
local base = {Cookies = {['OUTFOX_SEARCH_USER_ID_NCOO'] = '1536815481.8081024',['OUTFOX_SEARCH_USER_ID'] = '1773118125@192.168.0.1',},Headers = {['Accept'] = 'application/json, text/plain, */*',['Accept-Language'] = 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6',['Connection'] = 'keep-alive',['Origin'] = 'https://fanyi.youdao.com',['Referer'] = 'https://fanyi.youdao.com/',['Sec-Fetch-Dest'] = 'empty',['Sec-Fetch-Mode'] = 'cors',['Sec-Fetch-Site'] = 'same-site',['User-Agent'] ='Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36 Edg/120.0.0.0',['sec-ch-ua'] = '"Not_A Brand";v="8", "Chromium";v="120", "Microsoft Edge";v="120"',['sec-ch-ua-mobile'] = '?0',['sec-ch-ua-platform'] = '"Windows"',},Params = {['product'] = 'webdict',['appVersion'] = '1.0',['client'] = 'web',['mid'] = '1',['vendor'] = 'web',['screen'] = '1',['model'] = '1',['imei'] = '1',['network'] = 'wired',['keyfrom'] = 'webdict',['keyid'] = 'ai-write',['mysticTime'] = '',['yduuid'] = '',}
}-- 生成全局唯一用户id,同一id只有10次免费机会,每次生成不同id即可跳过免费限制
function genUUID()local UUID=luajava.bindClass 'java.util.UUID'return string.gsub(tostring(UUID.randomUUID()),'-','')
end--复制表
function copyTable(original)local copy = {}for key, value in pairs(original) doif type(value) == "table" thencopy[key] = copyTable(value) -- 递归复制子表elsecopy[key] = valueendendreturn copy
end-- 获得按键排序后的参数table
function getSortedParams(params)local function compare(a, b)return a[1] < b[1]endlocal sorted_params = {}for key, value in pairs(params) dotable.insert(sorted_params, { key, value })endtable.sort(sorted_params, compare)return sorted_params
end-- 获取token和key
function getTokenAndKey()local JSON=require 'cjson'local url = 'https://luna-ai.youdao.com/write/ai/web/ktf'-- 复制公共表头和参数local headers = copyTable(base.Headers)local params = copyTable(base.Params)local cookies = tableToStr(base.Cookies,";")-- 设置参数params['mysticTime']=getTimestamp()-- 生成yduuidbase.yduuid=genUUID()params['yduuid']=base.yduuid-- 按照table中键进行排序,并指定排序函数local sorted_params=getSortedParams(params)local encoded_params = tableToStr1(sorted_params)encoded_params = encoded_params .. "&key=xuiC95RuooxC8Q51UJtdod1plLUhdAmt"print("获取签名字符串"..encoded_params)local sign = md5Encrypt(encoded_params)print("获取签名的sign:"..sign)params['sign'] = signparams['pointParam'] ="appVersion,client,imei,keyfrom,keyid,mid,model,mysticTime,network,product,screen,vendor,yduuid,key"local finalUrl=url..'?'..tableToStr(params)print("请求地址"..finalUrl)-- 发送请求local httpTask=Http.get(finalUrl,cookies,nil,headers,function () end)local result=httpTask.get()local code,content,cookie,header=result[0],result[1],result[2],result[3]-- 解密数据local b64str=content:gsub(' ','+'):gsub('-','+'):gsub('_','/')-- des解密local key=md5Encrypt('IIS0fzL@zGv1^zO2%NcZiTcM=98WYxdun$CJE1KUKFfEhz&zpEC0fdXfvGqy*N!r',false)local iv=md5Encrypt('kG_oSxAXx#xjbiOKAkf9915Ko-XclOBP-GSgfo6E9ZB%9WvgcY6Y7dmje!+m5g#d',false)local s=tostring(decrypt(b64str,key,iv))s=string.gsub(s,'\x02','')print("token和sign"..s)local decodeData=JSON.decode(JSON.decode(s))return decodeData['sk'],decodeData['token']
end-- 获取翻译结果
function getResult(query)local JSON=require 'cjson'local url = 'https://luna-ai.youdao.com/write/ai/template/sse'-- 复制公共表头和参数local headers = copyTable(base.Headers)local params = copyTable(base.Params)-- 获取token和keylocal key,token=getTokenAndKey()-- 设置参数params['mysticTime']=getTimestamp()params['yduuid']=base.yduuidparams['keyid']='ai-write-web'params['functionId']='1'params['query']=urlEncode(query)params['userCustomize']=urlEncode(query)params['token']=token-- 设置头部local boundary="jeb3u3g5vh5v3hh2h2hg5g6v7vh4hehdjd"headers['Content-Type']='multipart/form-data;boundary='..boundaryheaders['Accept']='*/*, text/event-stream'headers["Referer"]="https://fanyi.youdao.com/aiwrite/document"-- 按照table中键进行排序,并指定排序函数local sorted_params=getSortedParams(params)local encoded_params=tableToStr1(sorted_params)encoded_params = encoded_params .. "&key="..keyprint('生成签名的参数字符串:::'..encoded_params)local sign = md5Encrypt(encoded_params)params['sign'] = signprint("签名结果:::"..sign)params['pointParam'] = 'appVersion,client,functionId,imei,keyfrom,keyid,mid,model,mysticTime,network,product,query,screen,token,userCustomize,vendor,yduuid,key'-- 处理sse事件流数据local OkHttpClient=luajava.bindClass 'okhttp3.OkHttpClient'local MultipartBody=luajava.bindClass 'okhttp3.MultipartBody'local Request=luajava.bindClass 'okhttp3.Request'local RealEventSource=luajava.bindClass 'okhttp3.internal.sse.RealEventSource'local EventSource=luajava.bindClass 'okhttp3.sse.EventSource'local EventSourceListener=luajava.bindClass 'okhttp3.sse.EventSourceListener'local TimeUnit=luajava.bindClass 'java.util.concurrent.TimeUnit'local client =OkHttpClient.Builder().connectTimeout(20,TimeUnit.SECONDS).readTimeout(20,TimeUnit.SECONDS).build()local requestBodyBuilder=MultipartBody.Builder().setType(MultipartBody.FORM)--添加请求参数for k,v in pairs(params) dorequestBodyBuilder.addFormDataPart(String(k),String(tostring(v)))endlocal requestBody=requestBodyBuilder.build()local requestBuilder = Request.Builder().url(url)-- 添加请求头for k,v in pairs(headers) dorequestBuilder.header(String(k),String(tostring(v)))endlocal request=requestBuilder.post(requestBody).build()-- 事件监听器local listener=EventSourceListener({onOpen=function(eventSource,response)print("建立sse链接")print(response)end,onEvent=function(eventSource,id,_type,data)-- 判断事件类型if _type=="message" then-- 更新uiactivity.runOnUiThread(Runnable{run=function()local result=JSON.decode(data)resultView.append(result["content"])end})endend,onFailure=function(eventSource,t,response)print("打开链接失败")end,onClose=function(eventSource)print("连接关闭")end})local eventSource=RealEventSource(request,listener)--开启事件源连接eventSource.connect(client)
end-- 测试
translateBtn.onClick=function()-- 清空上一次的结果resultView.setText("")local inputStr=tostring(inputText.getText())getResult(inputStr)
end
apk源码包及apk下载地址
- 源码:https://www.123pan.com/s/J5Nsjv-6XBN.html 提取码:SnKW
- apk:https://www.123pan.com/s/J5Nsjv-6XBN.html 提取码:SnKW
相关文章:
有道ai写作,突破免费限制,无限制使用
预览效果 文末提供源码包及apk下载地址 有道ai写作python版 import hashlib import time import json import ssl import base64 import uuidfrom urllib.parse import quote import requests from requests_toolbelt.multipart.encoder import MultipartEncoder from Crypto…...
node.js 使用 elementtree 生成思维导图 Freemind 文件
请参阅: java : pdfbox 读取 PDF文件内书签 请注意:书的目录.txt 编码:UTF-8,推荐用 Notepad 转换编码。 npm install elementtree --save 编写 txt_etree_mm.js 如下 // 读目录.txt文件,使用 elementtree 生成思维导图 Free…...
Vue中路由守卫的详细应用
作为一名web前端开发者,我们肯定经常使用Vue框架来构建我们的项目。而在Vue中,路由是非常重要的一部分,它能够实现页面的跳转和导航,提供更好的用户体验。然而,有时我们需要在路由跳转前或跳转后执行一些特定的逻辑&am…...
Flink Checkpoint过程
Checkpoint 使用了 Chandy-Lamport 算法 流程 1. 正常流式处理(尚未Checkpoint) 如下图,Topic 有两个分区,并行度也为 2,根据奇偶数 我们假设任务从 Kafka 的某个 Topic 中读取数据,该Topic 有 2 个 Pa…...
【Java程序代理与系统代理关系】Java程序代理与系统代理关系优先级及覆盖关系
前言 使用Apache HttpClient工具包中的HttpClients.createDefault()方法创建的默认HTTP客户端会根据操作系统当前的设置来决定是否使用代理。 具体来说,当创建默认HTTP客户端时,它会检查系统的代理设置。如果操作系统当前设置了系统级代理,…...
MQ,RabbitMQ,SpringAMQP的原理与实操
MQ 同步通信 异步通信 事件驱动优势: 服务解耦 性能提升,吞吐量提高 服务没有强依赖,不担心级联失败问题 流量消峰 小结: 大多情况对时效性要求较高,所有大多数时间用同步。而如果不需要对方的结果,且吞吐…...
Vue 3 + Koa2 + MySQL 开发和上线部署个人网站
Vue 3 Koa2 MySQL 开发和上线部署个人网站 记录个人的一个操作步骤, 顺序不分先后, 嫌啰嗦请出门右转! 环境说明: 服务器: 阿里云轻量应用服务器 服务器系统: CentOS8.2 本地环境: macOS 12.7.2 Node: 20.10.0 MySQL: 8.0.26 Vue: 3.3.11 Koa: 2.7.0 pm2: 5.3.1 Nginx: 1.1…...
uniapp踩坑之项目:简易版不同角色显示不一样的tabbar和页面
1. pages下创建三个不同用户身份的“我的”页面。 显示第几个tabbar,0是管理员 1是财务 2是司机 2. 在uni_modules文件夹创建底部导航cc-myTabbar文件夹,在cc-myTabbar文件夹创建components文件夹,在components文件夹创建cc-myTabbar.vue组件…...
源支付V7开心1.9修复版,非网络上泛滥不能那种
源支付V7开心1.9修复版,非网络上泛滥不能那种 修复版源码,非网络泛滥版,防止源码泛滥,会员专属源码, 本站会员免费下载所有资源 注:开发不易,仅限交流学习使用,如商业使用,请支持正…...
Gitlab和Jenkins集成 实现CI (二)
Gitlab和Jenkins集成 实现CI (一) Gitlab和Jenkins集成 实现CI (二) Gitlab和Jenkins集成 实现CI (三) 配置Gitlab api token 配置 Gitlab 进入gitlab #mermaid-svg-t84fR8wrT4sB4raQ {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:…...
Java:内部类、枚举、泛型以及常用API --黑马笔记
内部类 内部类是类中的五大成分之一(成员变量、方法、构造器、内部类、代码块),如果一个类定义在另一个类的内部,这个类就是内部类。 当一个类的内部,包含一个完整的事物,且这个事物没有必要单独设计时&a…...
【持续更新】2024牛客寒假算法基础集训营3 题解 | JorbanS
A - 智乃与瞩目狸猫、幸运水母、月宫龙虾 string solve() {string a, b; cin >> a >> b;if (isupper(a[0])) a[0] a - A;if (isupper(b[0])) b[0] a - A;return a[0] b[0] ? yes : no; }B - 智乃的数字手串 string solve() {cin >> n;int cnt 0;for (…...
Java基于微信小程序的驾校报名小程序,附源码
博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇…...
Android中AGP与Gradle、AS、JDK的版本关系
文章目录 AGP版本所要求的Gradle、JDK、SDK Build Tools最小版本Android Studio所要求的AGP最小版本 本文介绍了 在Android开发中由于AGP与gradle、JDK、AS等版本不匹配导致的编译失败问题屡见不鲜,尤其是对于新手而言更是叫苦不迭。新手经常遇到拿到别人的工程代码…...
web 前端实现一个根据域名的判断 来显示不同的logo 和不同的标题
1.需求 有可能我做一个后台 web端 我想实现一套代码的逻辑 显示不同的公司主题logo以及内容,但是实际上 业务逻辑一样 2.实现 建一个store oem.ts 这个名为是 oem系统 oem.ts import { defineStore } from pinia;import { store } from /store;const oemDataLis…...
复制和粘贴文本时剥离格式的5种方法(MacWindows)
您可能每天复制和粘贴多次。虽然它是一个非常方便的功能,但最大的烦恼之一就是带来了特殊的格式。从网络上获取一些文本,您经常会发现粘贴到文档中时,它保持原始样式。 我们将展示如何使用一些简单的技巧在不格式化的情况下复制和粘贴。 1.…...
SpringBoot实现即时通讯
SpringBoot实现即时通讯 功能简述 好友管理群组管理聊天模式:私聊、群聊消息类型:系统消息、文本、语音、图片、视频会话列表、发送消息、接收消息 核心代码 package com.qiangesoft.im.core;import com.alibaba.fastjson2.JSONObject; import com.q…...
【每日一题】LeetCode——反转链表
📚博客主页:爱敲代码的小杨. ✨专栏:《Java SE语法》 | 《数据结构与算法》 | 《C生万物》 ❤️感谢大家点赞👍🏻收藏⭐评论✍🏻,您的三连就是我持续更新的动力❤️ 🙏小杨水平有…...
精通Python爬虫:掌握日志配置
源码分享 https://docs.qq.com/sheet/DUHNQdlRUVUp5Vll2?tabBB08J2 在开发Python爬虫时,日志记录是一个不可或缺的特性,它帮助我们捕捉运行时信息、调试代码和监控爬虫的健康状况。合理地配置日志系统是提高爬虫可维护性的关键。本篇技术博客将详细介绍…...
Python_百度贴吧评论情感分析
一、评论爬取 以百度贴吧中“美团骑手吧”为例,对页面中的帖子评论进行爬取,并将结果以json的格式保存到本地中。 from lxml import etree import requests import json# 根据网页url获取评论 def GetComments(url):# 使用requests库发送GET请求&#…...
在 Nginx Stream 层“改写”MQTT ngx_stream_mqtt_filter_module
1、为什么要修改 CONNECT 报文? 多租户隔离:自动为接入设备追加租户前缀,后端按 ClientID 拆分队列。零代码鉴权:将入站用户名替换为 OAuth Access-Token,后端 Broker 统一校验。灰度发布:根据 IP/地理位写…...
渲染学进阶内容——模型
最近在写模组的时候发现渲染器里面离不开模型的定义,在渲染的第二篇文章中简单的讲解了一下关于模型部分的内容,其实不管是方块还是方块实体,都离不开模型的内容 🧱 一、CubeListBuilder 功能解析 CubeListBuilder 是 Minecraft Java 版模型系统的核心构建器,用于动态创…...
Frozen-Flask :将 Flask 应用“冻结”为静态文件
Frozen-Flask 是一个用于将 Flask 应用“冻结”为静态文件的 Python 扩展。它的核心用途是:将一个 Flask Web 应用生成成纯静态 HTML 文件,从而可以部署到静态网站托管服务上,如 GitHub Pages、Netlify 或任何支持静态文件的网站服务器。 &am…...
鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院查看报告小程序
一、开发环境准备 工具安装: 下载安装DevEco Studio 4.0(支持HarmonyOS 5)配置HarmonyOS SDK 5.0确保Node.js版本≥14 项目初始化: ohpm init harmony/hospital-report-app 二、核心功能模块实现 1. 报告列表…...
如何在最短时间内提升打ctf(web)的水平?
刚刚刷完2遍 bugku 的 web 题,前来答题。 每个人对刷题理解是不同,有的人是看了writeup就等于刷了,有的人是收藏了writeup就等于刷了,有的人是跟着writeup做了一遍就等于刷了,还有的人是独立思考做了一遍就等于刷了。…...
代理篇12|深入理解 Vite中的Proxy接口代理配置
在前端开发中,常常会遇到 跨域请求接口 的情况。为了解决这个问题,Vite 和 Webpack 都提供了 proxy 代理功能,用于将本地开发请求转发到后端服务器。 什么是代理(proxy)? 代理是在开发过程中,前端项目通过开发服务器,将指定的请求“转发”到真实的后端服务器,从而绕…...
网站指纹识别
网站指纹识别 网站的最基本组成:服务器(操作系统)、中间件(web容器)、脚本语言、数据厍 为什么要了解这些?举个例子:发现了一个文件读取漏洞,我们需要读/etc/passwd,如…...
初探Service服务发现机制
1.Service简介 Service是将运行在一组Pod上的应用程序发布为网络服务的抽象方法。 主要功能:服务发现和负载均衡。 Service类型的包括ClusterIP类型、NodePort类型、LoadBalancer类型、ExternalName类型 2.Endpoints简介 Endpoints是一种Kubernetes资源…...
MFC 抛体运动模拟:常见问题解决与界面美化
在 MFC 中开发抛体运动模拟程序时,我们常遇到 轨迹残留、无效刷新、视觉单调、物理逻辑瑕疵 等问题。本文将针对这些痛点,详细解析原因并提供解决方案,同时兼顾界面美化,让模拟效果更专业、更高效。 问题一:历史轨迹与小球残影残留 现象 小球运动后,历史位置的 “残影”…...
MySQL 部分重点知识篇
一、数据库对象 1. 主键 定义 :主键是用于唯一标识表中每一行记录的字段或字段组合。它具有唯一性和非空性特点。 作用 :确保数据的完整性,便于数据的查询和管理。 示例 :在学生信息表中,学号可以作为主键ÿ…...
