相关文章
typecho代码高亮 typecho控制台怎么进入
2024-12-18 21:48

typecho重新升级至1.2.0(实际上是重新删除后安装)后,typecho始终无法登录后台。

PHP这种Web编程语言实在没接触过,花了两天来玩一下。

博客网站使用的技术:nginx+php-fpm+typecho(sqlite),nginx与php实际运行一个ARM电视盒子上。

正常运行的网站,各种调试、日志都是关闭的,因此,首先打开php-fpm的日志捕获开关:

;catch_workers_output=no

修改为yes,并将首字符;去掉。

此开关打开后,php的error_log就可以输出信息了。

同时将php.ini的显示错误开关打开:

;display_errors=off

修改为display_errors=on。

修改好这些开关后,重启php-fpm的服务。

之后就可以在typecho的php代码中增加error_log以观察代码的运行轨迹。

登录链接代码在typecho的admin目录login.php,但实际提交的代码为:

https://XXX.XXX.net/blog/index.php/action/login?_=7cf73d0584c577c96833bd2e3a58e0f0

_=后面的字符为一串md5字符,可以不管。

而这个链接首先会被nginx的fastcgi_split_path_info功能拆分,对于blog的fastcgi_split_path_info代码如下:

fastcgi_split_path_info后面的正则表达式,将/blog/index.php/action/login?_=7cf73d0584c577c96833bd2e3a58e0f0链接拆分成两个group

分别是:

/blog/index.php

/action/login?_=7cf73d0584c577c96833bd2e3a58e0f0

然后用$fastcgi_script_name与$fastcgi_path_info存放。

在其后的

将后部内容传递至PATH_INFO(这个变量在typecho中,即可通过从request头部中获取PATH_INFO变量来取得)

实际执行脚本的是/blog/index.php

但从index.php来看,代码很简单:

从网络中,搜索一堆资料,了解到,关键代码在TypechoRouter::dispatch()

主要内容即根据数据库中的路由表,分别调用创建对应的Widget,然后调用相应Widget的action函数。

在Router.php的dispatch函数中加上相应的日志输出对应的widget。

从日志看出/action/login?_=7cf73d0584c577c96833bd2e3a58e0f0对应的widget为WidgetAction

对于varWidgetAction.php的代码见内:

基本思想来看,查map表,然后转到对应的类。对于当前动作,login显然对应到WidgetLogin.php。

WidgetLogin.php的代码如下:

在此action函数中,加上相应日志,问题定位到此处代码:

代码在执行到此行,即已经返回,也就根本没有再执行后面的校验用户名、密码等动作。

protect函数的代码如下,相当简单

在此函数中加上日志定位到,此处的request->get('_')获取即为请求中的7cf73d0584c577c96833bd2e3a58e0f0,

而getToken函数如下:

根据token与request的getReferer计算的一个md5内容。

token及相应计算规则应该是没有问题的,因此怀疑点定位到getReferer函数的返回内容。

在网上搜索一番后,发现已经有人记录了此种问题及相应解决办法,链接:https://blog.warhut.cn/dmbj/423.html

引用如下:

------------------------------------------------------------------------------------------------------------------

如果加入了,将会导致无法登录后台,原因如下:

由于是通过登录的后台地址,传输参数,所以当加入之后相当于删除了提交的地址。

通过下面即可解决,加在中。

------------------------------------------------------------------------------------------------------------------

解决办法,先在adminHeader.php中加入上面的referer行,如下:

加入后,登录功能即正常,但blog首页中的退出登录还有问题,点击退出类似于登录异常的情形,直接返回。

采取在首页相应的header处,添加相应代码。

themes中的header.php中代码如下(默认theme):

这儿首页的header()函数,实际对应到var/Widget/Archive.php中的header函数,

即可解决首页退出登录情况。

 


    以上就是本篇文章【typecho代码高亮 typecho控制台怎么进入】的全部内容了,欢迎阅览 ! 文章地址:http://fswenzheng.xhstdz.com/news/11750.html 
     栏目首页      相关文章      动态      同类文章      热门文章      网站地图      返回首页 物流园资讯移动站 http://fswenzheng.xhstdz.com/mobile/ , 查看更多   
最新文章
短视频创作新突破,AI工具助力内容升级!
在信息爆炸的数字时代,短视频已成为大众获取信息、娱乐和互动的重要途径。无论是个人创作者还是企业品牌,利用短视频平台提升曝
网站SEO优化的想法及基本步骤你了解吗?
SEO基础优化,如何做好网站优化,包括通过网站SEO优化技术对网站进行排名,如何做好网站优化并掌握网站SEO优化技能,这可以为用
电脑分区是使用MBR还是GPT呢看了这篇文章心里就有底了
https://m.toutiao.com/is/iNSkpuUm/?=在Windows 10或Windows 11上设置一个新磁盘,系统会询问你是要使用MBR(主引导记录)还是G
网站权重多少才好赚钱?深入剖析市场行情与(黑帽seo)资讯
在当今数字化的商业世界中,拥有一个网站已成为许多企业和个人拓展业务、获取收益的重要途径,而网站权重则是衡量一个网站在搜索
SEO常用工具全解析
在当今的数字时代,搜索引擎优化(SEO)已成为企业在线营销不可或缺的一部分,无论是小型企业还是大型公司,都需要通过优化网站
莱西网站排名优化费用,提升网站排名的有效策略与成本分析,莱西网站推广公司
莱西网站排名优化费用及策略分析显示,提升网站排名需综合考虑关键词研究、内容优化、外部链接建设等因素。不同策略成本各异,如
西城区特色礼品电商新格局,礼品与推广策略解析
西城区礼品策略聚焦区域特色,旨在打造特色礼品电商新格局。通过精心策划的网站架构和推广策略,结合地方文化元素,提升用户体验
如何通过十大免费网站推广入口提升品牌知名度:免费方式帮助你轻松吸引流量
在数字化营销和互联网推广的浪潮中,很多企业和个人都在寻找高效且低成本的推广方式。尤其是对于初创企业或小型商家来说,选择合
著名作家,如何迅速进入SEO领域?
这是一个信息快速传播的时代,内容仍然是一非常有力的传播载体,特别是对于写作能力非常强的人,有的时候可以轻松的通过文字获得
AI新纪元:探索搜狐简单AI助力创作的无限可能!
在一个快节奏的数字时代,创作的方式正在发生深刻变化。想象一下,一个设计团队在进行品牌推广时,几乎所有的创意图像和文案都可
相关文章