前端仅传path路径给后端,避免攻击

前端

javascript 复制代码
async function getpath(path){
    try{
        const response = await fetch('http://127.0.0.1:8080/getDownUrl/',{
        method : 'POST',
        headers: {
            'Content-Type' : 'application/json',
        },
        body:JSON.stringify({path:path})

    });
    if (!response.ok){
        showError('请求路径异常,请稍后重试!');
    }
    const data = await response.json();
    return data;
    }catch(error){
        showError('请求路径异常:${error.message}');
        throw error;
    }

}

//监听上传请求完成
xhr.addEventListener('load',()=>{
    if (xhr.status === 200){
    const res = JSON.parse(xhr.responseText);
    //这里DOWNLOAD_FILE_URL,后续改为服务器配置,前端仅传入path给后端,避免被攻击的风险。
    const path = res.Result.Path;
    getapath(path)
        .then(result =>{
        console.log('获取到的数据:',result);
        const d_url  = result.content;
        // 传输完成后,更新为待处理字样
        updateProgress(attachment.id, DICT.UPLOAD_COMPLETED);
        
        // 将文件路径记录在对应的input里面
        let tempInput = document.getElementById(attachment.id);
        tempInput.value = d_url;

        // 上传完成后 校验 激活 开始处理按钮
        validFileList(); 
      
})
        .catch(error =>{
            console.log('操作失败请重试',error); 
}); 
}else{
    showError('转写失败,请重试');
}

});

后端

python 复制代码
calss GetDownUrl(BaseModel):
    path:str


@app.post('/getDownUrl/')
async def get_down_url(request:GetDownUrl):
    """获取下载路径"""
    path  = request.path

    try:
        if path:
            down_url = f'{DOWN_URL_IP}/api/true&Path={Path}'
        else:
            return {'status':1,"content":'',"error_msg":""}
    except Exception as e:
        error_msg = f"传入path错误: {str(e)}"
        logger.error(error_msg)
        return {'status':0,"content":'',"error_msg":error_msg}
相关推荐
于慨1 天前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz1 天前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶1 天前
前端交互规范(Web 端)
前端
CHU7290351 天前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
GISer_Jing1 天前
Page-agent MCP结构
前端·人工智能
王霸天1 天前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航1 天前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界1 天前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript
PieroPc1 天前
一个功能强大的 Web 端标签设计和打印工具,支持服务器端直接打印到局域网打印机。Fastapi + html
前端·html·fastapi
悟空瞎说1 天前
深入 Vue3 响应式:为什么有的要加.value,有的不用?从设计到源码彻底讲透
前端·vue.js