当前位置: 首页 > news >正文

人民日报网站谁做的网站建设是什么工作

人民日报网站谁做的,网站建设是什么工作,虚拟偶像定制app,网站建设 powered by 祥云平台使用session_exec 、file_fdw以及自定义函数实现该功能。 缺陷:实测发现锁用户后,进去解锁特定用户。只能允许一次登陆,应该再次登陆的时候,触发函数,把之前的日志里的错误登陆的信息也计算到登录次数里了。而且foreig…

使用session_exec 、file_fdw以及自定义函数实现该功能。

缺陷:实测发现锁用户后,进去解锁特定用户。只能允许一次登陆,应该再次登陆的时候,触发函数,把之前的日志里的错误登陆的信息也计算到登录次数里了。而且foreign table不能在数据库里清理。需要删除对应的pg_log,才能使foreign table信息清理掉,来重制该用户的密码错误记录。

https://github.com/okbob/session_exec

unzip session_exec-master.zip
cd session_exec-master/
make pg_config=$PGHOME/bin/pg_config
make pg_config=$PGHOME/bin/pg_config install

更改配置文件

logging_collector = on 
log_destination = 'csvlog' 
session_preload_libraries='session_exec'
session_exec.login_name='login'

     更改完之后需要重启数据库

pg_ctl restart

安装file_fdw扩展

cd contrib/file_fdw/
# 安装命令
make && make install

创建外部表postgres_log

create extension file_fdw;CREATE SERVER pglog FOREIGN DATA WRAPPER file_fdw;CREATE FOREIGN TABLE public.postgres_log(
log_time timestamp(3) with time zone,user_name text,database_name text,process_id integer,connection_from text,session_id text,session_line_num bigint,command_tag text,session_start_time timestamp with time zone,virtual_transaction_id text,transaction_id bigint,error_severity text,sql_state_code text,message text,detail text,hint text,internal_query text,internal_query_pos integer,context text,query text,query_pos integer,location text,application_name text
) SERVER pglog
OPTIONS ( program 'find /home/pg13/data/log/ -type f -name "*.csv" -mtime -1 -exec cat {} \;', format 'csv' );grant SELECT on postgres_log to PUBLIC;

如下设置的是5 5次登录失败就锁定用户

create or replace function public.login() returns void as $$
declare
res record;
failed_login_times int = 5;
failed_login int = 0;
begin
--获取数据库中所有可连接数据库的用户
for res in select rolname from pg_catalog.pg_roles where rolcanlogin= 't' and rolname !='postgres'
loopraise notice 'user: %!',res.rolname;--获取当前用户最近连续登录失败次数select count(*)from (select log_time,user_name,error_severity,message,detail from public.postgres_log where command_tag = 'authentication' and user_name = res.rolname and (detail is null or detail not like 'Role % does not exist.%') order by log_time desc limit failed_login_times) AWHERE A.error_severity='FATAL'into  failed_login ;raise notice 'failed_login_times: %! failed_login: %!',failed_login_times,failed_login;--用户最近密码输入错误次数达到5次或以上if failed_login >= failed_login_times then--锁定用户EXECUTE format('alter user %I nologin',res.rolname);raise notice 'Account % is locked!',res.rolname;end if;
end loop;
end;
$$ language plpgsql strict security definer set search_path to 'public';

用户是否被锁/是否允许登陆,可以查看pg_roles系统视图里的rolcanlogin字段。

验证密码失败:

使用如下语句,可以查询登陆失败的记录。

select log_time,user_name,error_severity,message,detail from public.postgres_log where command_tag = 'authentication'  order by log_time desc limit 10 offset 0;

解锁用户命令如下:

alter user test_user login;

解锁同时需要删除pg_log下csv文件里的对应有改用户登陆失败的日志记录,重制密码登录错误的记录,否则可能会重复计算之前的错误登陆记录。

http://www.dt0577.cn/news/2374.html

相关文章:

  • 做单平台网站制作阻断艾滋病的药有哪些
  • 如何在局域网做网站哈尔滨seo网站管理
  • 找兼职工作在家做正规网站淘宝营销推广方案
  • 监控做直播网站百度竞价排名危机事件
  • 做网站的设计公司如何推广品牌
  • 网站免费建立看广告收益最高的软件
  • 全球疫情实时动态查询谷歌seo是做什么的
  • 人才网网站模板网站排名怎么做上去
  • 云虚拟主机 wordpress优化网站结构一般包括
  • 门户网站制作定做搜狗站长平台主动提交
  • 汕头建筑小红书seo是什么
  • 天津网站定制公司百度登陆页面
  • 招聘网站做招聘顾问百度收录网址
  • 金融行业网站建设方案谷歌seo站内优化
  • 网站建设人员架构国外市场网站推广公司
  • 做装修的有那些网站宁波seo推广定制
  • 做十个网站山东服务好的seo
  • 扫描网站漏洞的软件seo长沙
  • 做技术开发的网站百度收录教程
  • 网站建设团队新乡网络推广外包
  • 易语言可以做网站嘛推广的渠道和方法有哪些
  • 电影网站怎么做推广百度指数在线查询工具
  • 高端家具东莞网站建设技术支持百度指数分析
  • 做电影网站如何推广方案手机在线制作网站
  • 关于旅游网站建设的摘要百度竞价调价软件
  • 什么程序做的网站没有index页面seo研究中心vip教程
  • 北京建网站定制价格seogw
  • 株洲网站建设服务公司中国职业培训在线官方网站
  • 淄博政府做网站哪家好百度关键词排名突然消失了
  • 网站建设加空间百度权重5的网站能卖多少钱