Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
F
fzm-joying
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
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lei
fzm-joying
Commits
ef434138
Commit
ef434138
authored
Jul 28, 2021
by
tangtuo
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
解决同一个用户可以并发领取纪念版nft的问题
parent
94363fad
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
15 additions
and
2 deletions
+15
-2
RedisConstant.java
.../src/main/java/com/fzm/common/constant/RedisConstant.java
+1
-1
CommemorateNftServiceImpl.java
...om/fzm/common/service/impl/CommemorateNftServiceImpl.java
+14
-1
No files found.
joying-common/src/main/java/com/fzm/common/constant/RedisConstant.java
View file @
ef434138
...
...
@@ -29,7 +29,7 @@ public class RedisConstant {
/**
* 纪念版nft领取成员列表
*/
public
static
final
String
COMMEMORATE_NFT_MEMBERS_PREFIX
=
"commemorateNft:members"
;
public
static
final
String
COMMEMORATE_NFT_MEMBERS_PREFIX
=
"commemorateNft:members
:
"
;
...
...
joying-common/src/main/java/com/fzm/common/service/impl/CommemorateNftServiceImpl.java
View file @
ef434138
...
...
@@ -22,6 +22,7 @@ import com.fzm.common.utils.JsonUtil;
import
com.fzm.common.utils.RedisUtil
;
import
lombok.extern.slf4j.Slf4j
;
import
org.apache.commons.lang3.StringUtils
;
import
org.redisson.api.RLock
;
import
org.redisson.api.RSemaphore
;
import
org.redisson.api.RedissonClient
;
import
org.springframework.beans.factory.annotation.Value
;
...
...
@@ -103,11 +104,19 @@ public class CommemorateNftServiceImpl extends ServiceImpl<CommemorateNftMapper,
@Override
public
Boolean
receive
(
Integer
id
)
{
User
user
=
userService
.
getUserByToken
();
// 加锁,避免一个用户可以并发领取
RLock
lock
=
redisson
.
getLock
(
"receive:nft:"
+
user
.
getId
());
boolean
tryLock
=
lock
.
tryLock
();
if
(!
tryLock
){
throw
GlobalException
.
newException
(
ResultCode
.
RECEIVE_ERROR
,
"操作频繁"
);
}
try
{
CommemorateNft
commemorateNft
=
getById
(
id
);
if
(
commemorateNft
==
null
)
{
throw
GlobalException
.
newException
(
ResultCode
.
DATA_ERROR
,
"没找到此纪念版nft详情,请稍后再试"
);
}
User
user
=
userService
.
getUserByToken
();
// 先判断当前用户有没有领取过此纪念版nft
if
(
redisUtil
.
sIsMember
(
RedisConstant
.
COMMEMORATE_NFT_MEMBERS_PREFIX
+
id
,
user
.
getId
().
toString
()))
{
throw
GlobalException
.
newException
(
ResultCode
.
FAILED
,
"此纪念版nft每个用户只能领取一次"
);
...
...
@@ -153,6 +162,10 @@ public class CommemorateNftServiceImpl extends ServiceImpl<CommemorateNftMapper,
// 领取完毕,把当前用户id加入到纪念版nft的领取记录中
redisUtil
.
sAdd
(
RedisConstant
.
COMMEMORATE_NFT_MEMBERS_PREFIX
+
id
,
user
.
getId
().
toString
());
return
true
;
}
finally
{
lock
.
unlock
();
}
}
public
static
void
main
(
String
[]
args
)
{
...
...
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