Skip to content
Toggle navigation
P
Projects
G
Groups
S
Snippets
Help
CnChunfeng
/
ichunt_lua_waf
This project
Loading...
Sign in
Toggle navigation
Go to a project
Project
Repository
Issues
0
Merge Requests
0
Pipelines
Wiki
Snippets
Settings
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Commit
488ba8bd
authored
Oct 19, 2020
by
Joneq
Browse files
Options
_('Browse Files')
Download
Email Patches
Plain Diff
修改代码
parent
195dc4ec
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
14 additions
and
16 deletions
waf.lua
waf.lua
View file @
488ba8bd
...
@@ -12,7 +12,7 @@ local config = require "config"
...
@@ -12,7 +12,7 @@ local config = require "config"
local
redis
=
require
"resty.redis"
local
redis
=
require
"resty.redis"
local
redirect
=
require
"redirect"
local
redirect
=
require
"redirect"
local
localstring
=
require
"localstring"
local
localstring
=
require
"localstring"
local
wafcheck
=
require
"wafcheck"
--
local wafcheck = require "wafcheck"
local
reqhandle
=
require
"reqhandle"
local
reqhandle
=
require
"reqhandle"
-------加载.so扩展包
-------加载.so扩展包
...
@@ -34,7 +34,7 @@ end
...
@@ -34,7 +34,7 @@ end
-------链接redis------------
-------链接redis------------
red
=
redis
:
new
()
local
red
=
redis
:
new
()
red
:
set_timeout
(
1000
)
red
:
set_timeout
(
1000
)
local
ok
,
err
=
red
:
connect
(
config
.
redis_host
,
config
.
redis_port
)
local
ok
,
err
=
red
:
connect
(
config
.
redis_host
,
config
.
redis_port
)
...
@@ -85,28 +85,26 @@ user_ip = reqhandle.GetRealIp()
...
@@ -85,28 +85,26 @@ user_ip = reqhandle.GetRealIp()
u_agent
=
ngx
.
req
.
get_headers
().
user_agent
u_agent
=
ngx
.
req
.
get_headers
().
user_agent
ngx
.
say
(
user_ip
)
local
is_exist
,
err
=
red
:
sismember
(
'ichunt_waf_black_ip'
,
user_ip
)
ngx
.
say
(
is_exist
)
ngx
.
exit
(
ngx
.
HTTP_FORBIDDEN
)
-- 白名单存在直接跳过
-- 白名单存在直接跳过
if
wafcheck
.
WhiteIp
(
user_ip
)
==
'exist'
or
wafcheck
.
WhiteUrl
(
temp_uri
)
==
'exist'
or
wafcheck
.
WhiteHeader
(
u_agent
)
==
'exist'
then
-- if wafcheck.WhiteIp(user_ip) == 'exist' or wafcheck.WhiteUrl(temp_uri) == 'exist' or wafcheck.WhiteHeader(u_agent) == 'exist' then
return
-- return
end
-- end
ngx
.
say
(
user_ip
)
ngx
.
say
(
wafcheck
.
BlackIp
(
user_ip
))
ngx
.
exit
(
ngx
.
HTTP_FORBIDDEN
)
-- 黑名单存在直接302
-- 黑名单存在直接302
if
wafcheck
.
BlackIp
(
user_ip
)
==
'exist'
or
wafcheck
.
BlackUrl
(
temp_uri
)
==
'exist'
or
wafcheck
.
BlackHeader
(
u_agent
)
==
'exist'
then
-- if wafcheck.BlackIp(user_ip) == 'exist' or wafcheck.BlackUrl(temp_uri) == 'exist' or wafcheck.BlackHeader(u_agent) == 'exist' then
ngx
.
say
(
wafcheck
.
BlackIp
(
user_ip
))
ngx
.
exit
(
ngx
.
HTTP_FORBIDDEN
)
ngx
.
say
(
1
)
return
-- ngx.exit(ngx.HTTP_FORBIDDEN)
end
-- return
-- end
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment