Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
C
courseSign
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
JIRA
JIRA
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
szh
courseSign
Commits
4c579f13
Commit
4c579f13
authored
Nov 29, 2024
by
szh
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
update
parent
f3acae1c
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
24 additions
and
9 deletions
+24
-9
course_users.go
server/api/v1/course/course_users.go
+16
-2
verifySig.go
server/utils/chain33/verifySig.go
+8
-7
No files found.
server/api/v1/course/course_users.go
View file @
4c579f13
...
@@ -13,6 +13,7 @@ import (
...
@@ -13,6 +13,7 @@ import (
twiReq
"courseSign/server/model/twi/request"
twiReq
"courseSign/server/model/twi/request"
"courseSign/server/service"
"courseSign/server/service"
"courseSign/server/utils"
"courseSign/server/utils"
"courseSign/server/utils/chain33"
"github.com/33cn/chain33/common/address"
"github.com/33cn/chain33/common/address"
"github.com/gin-gonic/gin"
"github.com/gin-gonic/gin"
"github.com/go-redis/redis/v8"
"github.com/go-redis/redis/v8"
...
@@ -265,11 +266,24 @@ func (courseUsersApi *CourseUsersApi) MetaMaskLogin(c *gin.Context) {
...
@@ -265,11 +266,24 @@ func (courseUsersApi *CourseUsersApi) MetaMaskLogin(c *gin.Context) {
response
.
FailWithMessage
(
err
.
Error
(),
c
)
response
.
FailWithMessage
(
err
.
Error
(),
c
)
return
return
}
}
if
time
.
Now
()
.
Unix
()
-
1800
>
signTime
{
if
time
.
Now
()
.
Unix
()
/
1000
-
1800
>
signTime
{
response
.
FailWithMessage
(
"签名时间已过期,请重新签名"
,
c
)
response
.
FailWithMessage
(
"签名时间已过期,请重新签名"
,
c
)
return
return
}
}
var
eipSign
chain33
.
EIP191
eipSign
.
Signature
=
loginUser
.
Signature
eipSign
.
Msg
=
loginUser
.
Msg
eipSign
.
Address
=
loginUser
.
Addr
pass
,
err
:=
chain33
.
VerifyPersonalSign
(
eipSign
)
if
err
!=
nil
{
global
.
GVA_LOG
.
Error
(
"VerifyPersonalSign"
,
zap
.
Error
(
err
))
response
.
FailWithMessage
(
"验签失败"
,
c
)
return
}
if
!
pass
{
response
.
FailWithMessage
(
"验签未通过"
,
c
)
return
}
// device token
// device token
deviceCode
:=
utils
.
CreateDeviceCode
(
loginUser
.
Addr
)
deviceCode
:=
utils
.
CreateDeviceCode
(
loginUser
.
Addr
)
...
...
server/utils/chain33/verifySig.go
View file @
4c579f13
...
@@ -10,9 +10,9 @@ import (
...
@@ -10,9 +10,9 @@ import (
)
)
type
EIP191
struct
{
type
EIP191
struct
{
m
sg
string
M
sg
string
s
ignature
string
S
ignature
string
a
ddress
string
A
ddress
string
}
}
func
check
(
e
error
)
{
func
check
(
e
error
)
{
...
@@ -36,7 +36,7 @@ func signEIP191(message string) common.Hash {
...
@@ -36,7 +36,7 @@ func signEIP191(message string) common.Hash {
}
}
func
VerifyPersonalSign
(
eipChallenge
EIP191
)
(
bool
,
error
)
{
func
VerifyPersonalSign
(
eipChallenge
EIP191
)
(
bool
,
error
)
{
decodedSig
,
err
:=
hexutil
.
Decode
(
eipChallenge
.
s
ignature
)
decodedSig
,
err
:=
hexutil
.
Decode
(
eipChallenge
.
S
ignature
)
if
err
!=
nil
{
if
err
!=
nil
{
return
false
,
err
return
false
,
err
}
}
...
@@ -50,7 +50,7 @@ func VerifyPersonalSign(eipChallenge EIP191) (bool,error) {
...
@@ -50,7 +50,7 @@ func VerifyPersonalSign(eipChallenge EIP191) (bool,error) {
decodedSig
[
64
]
-=
27
// shift byte?
decodedSig
[
64
]
-=
27
// shift byte?
}
}
hash
:=
signEIP191
(
eipChallenge
.
m
sg
)
hash
:=
signEIP191
(
eipChallenge
.
M
sg
)
recoveredPublicKey
,
err
:=
crypto
.
Ecrecover
(
hash
.
Bytes
(),
decodedSig
)
recoveredPublicKey
,
err
:=
crypto
.
Ecrecover
(
hash
.
Bytes
(),
decodedSig
)
if
err
!=
nil
{
if
err
!=
nil
{
...
@@ -64,7 +64,7 @@ func VerifyPersonalSign(eipChallenge EIP191) (bool,error) {
...
@@ -64,7 +64,7 @@ func VerifyPersonalSign(eipChallenge EIP191) (bool,error) {
recoveredAddress
:=
crypto
.
PubkeyToAddress
(
*
secp256k1RecoveredPublicKey
)
.
Hex
()
recoveredAddress
:=
crypto
.
PubkeyToAddress
(
*
secp256k1RecoveredPublicKey
)
.
Hex
()
fmt
.
Println
(
"Signature matches known address!"
,
"recover addr "
,
recoveredAddress
,
"req addr"
,
eipChallenge
.
a
ddress
)
fmt
.
Println
(
"Signature matches known address!"
,
"recover addr "
,
recoveredAddress
,
"req addr"
,
eipChallenge
.
A
ddress
)
return
hasMatchingAddress
(
eipChallenge
.
a
ddress
,
recoveredAddress
),
nil
return
hasMatchingAddress
(
eipChallenge
.
A
ddress
,
recoveredAddress
),
nil
}
}
\ No newline at end of file
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