Next.js 求助 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Juppiter
V2EX    前端开发

Next.js 求助

  •  
  •   Juppiter 2023-08-07 14:04:44 +08:00 1494 次点击
    这是一个创建于 797 天前的主题,其中的信息可能已经有所发展或是发生改变。

    RT. 有没有什么办法可以让浏览器在请求页面的时候 SSR 服务端拿到浏览器的数据(比如说浏览器的默认语言)。除了使用 cookie 和 queryString 的方式。

    9 条回复    2023-08-09 13:24:58 +08:00
    USDT
        1
    USDT  
       2023-08-07 14:20:07 +08:00   1
    看你用的是 pages router 还是 app router ,本质上从请求的 headers 里面判断

    // 比方说拿 user agent
    pages router:

    export async function getServerSideProps({ req }: { req: NextRequest }) {
    const headers = req.headers;
    console.log('!!!', headers);
    return { props: { ua: headers.get('user-agent') } };
    }


    app router:
    // 注意不能在'use client'的文件里面用
    import { headers } from 'next/headers';

    export default function Home() {
    const hs = headers();
    console.log('>>>>>>>>>>>', hs.get('user-agent'))
    return (
    <main>
    Your agent is: {hs.get('user-agent')}
    </main>
    )
    }
    mdn
        2
    mdn  
       2023-08-07 14:21:29 +08:00
    js: navigator.languages
    服务器: request headers - Accept-Language
    Juppiter
        3
    Juppiter  
    OP
       2023-08-07 14:25:56 +08:00
    @USDT #1 可能我的描述不清楚。 目前的问题不是拿的问题,可能有自定义数据需要从浏览器取到服务端,这样的话用户从浏览器发送请求到服务端,在我的认知是没办法去加一个 custom header 让服务端拿到的吧
    Juppiter
        4
    Juppiter  
    OP
       2023-08-07 14:26:46 +08:00
    @mdn #2 如果不单是语言还有自定义数据怎么在服务端拿到呢
    mdn
        5
    mdn  
       2023-08-07 14:32:21 +08:00
    @Juppiter #4 如果是浏览器特定字段,可以从请求头中获取,比如语言等
    如果需要自定义,那就只能 cookie 和 url query string
    USDT
        6
    USDT  
       2023-08-07 14:36:05 +08:00
    @Juppiter 弱问一句浏览器是否是你们自己可控的呢,比方说微信在点开链接的时候是自己的 web view 套了一层,那么这个时候他就可以有办法加自定义字段……如果就是普通的 Chrome 之类的应该是没办法的
    fenglirookie
        7
    fenglirookie  
       2023-08-08 14:54:26 +08:00
    @USDT 他应该就是这个意思,就是在自己研发的 app webview 里面打开 nextjs 项目,在 nextjs 项目中拿到 webview 注入的自定义字段,再把这个字段传到 数据接口后台,这套我也没跑通(主要是没办法做得很通用)
    USDT
        8
    USDT  
       2023-08-08 16:57:23 +08:00
    @fenglirookie 嗯。。那我好奇问下做不到很通用的原因是啥呢,我理解最不济就是加几个自定义 header 的事情。是因为自定义数据比较复杂,嵌套层数可能比较多,想用类似 json 格式来做吗
    fenglirookie
        9
    fenglirookie  
       2023-08-09 13:24:58 +08:00
    @USDT 我之前的做法是在_app.tsx 里面 使用某个钩子函数,在这个钩子函数中获取 cookie 里面的内容,复制到 axios 的原型上,但是后来发现服务端客户端不互通,我已经搞了几个月了都没成功 ,我建议你还是换一种方案。就是使用官网推荐的方式在 page/api 下面定义一次接口,在这里面就可以随便获取,而且客户端无感,倒是安全系数蛮高
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2703 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 24ms UTC 08:54 PVG 16:54 LAX 01:54 JFK 04:54
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86