web——德州扑克

1.此案例只用于学习

2.未接入游戏规则

   

HTML代码部分 
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<meta name="viewport" content="width=device-width">
		<meta name="Poker Skin" content="Poker Skin">
		<meta name="keywords" content="Reece, Poker, Camp">
		<title>德州扑克</title>
		<link rel="stylesheet" href="style.css">
	</head>
	<body>
		<div id="poker-wrapper" class="poker-wrapper">
			<!-- 桌面 -->
			<div class="pocker-desktop">
				<h3>Total Pot: $<span class="total-amount"></span></h3>
				<div class="poker-cards-list"></div>
			</div>
			<!-- 用户 -->
			<div class="poker-user-list"></div>
			<!-- 按钮 -->
			<div class="btn-wrapper">
				<!-- 游戏开始 -->
				<div class="btn start-game">
					开始游戏
				</div>
				<div class="btn user-call">
					玩家跟注
				</div>
				<div class="btn user-raise">
					玩家加注
				</div>
				<div class="btn user-abstention">
					玩家弃牌
				</div>
			</div>
		    <!-- 公布栏 -->
			<div class="bulletin-board-wrapper">
				<div class="bulletin-board-title">公布栏</div>
				<div class="bulletin-board-info">
					<div class="info-list">
					</div>
				</div>
			</div>
		</div>
	</body>
	<script src="index.js"></script>
</html>
CSS代码部分
/* 设置css 变量 */
/* ♠ ♥ ♣ ♦ */
:root {
	--bg-color: #676769;
	--font-color: #fff;
	--default-border-color: #fff;
	--desktop-bg-color: #151515;
	/* 花色 */
	--decor1: url("");
	--decor2: url("");
	--decor3: url("");
	--decor4: url("");
	--poker-bg-default: #c1c1c1;
	--poker-bg-color1: #2bbf29;
	--poker-bg-color2: #df4538;
	--poker-bg-color3: #3077cc;
	--poker-bg-color4: #FEC801;
	--poker-border-color: #fff;

	/* 筹码  */
	--big-blind-bg-color: #3077cc;
	--small-blind-bg-color: #ff0000;

	--info-panel-bg-color: rgba(0, 0, 0, 0.2);

	/*  按钮背景色*/
	--btn-type1: #2bbf29;
	--btn-type2: #3077cc;
	--btn-type3: #FEC801;
	--btn-type4: #df4538;
	--btn-border-color: #333;
	--btn-box-shadow: 1px 1px 5px 0px rgba(50, 50, 50, 0.75);
}


* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	font-family: Serif;
}

body {
	width: 100vw;
	height: 100vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background-color: var(--bg-color);
}

.poker-wrapper {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: relative;
}

.poker-wrapper .pocker-desktop {
	width: 48em;
	height: 24em;
	color: var(--font-color);
	background-color: var(--desktop-bg-color);
	border-radius: 20em;
	border: 2em solid var(--desktop-border-color);
	z-index: 2;
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 1.0em;
}

.poker-wrapper .pocker-desktop .total-amount {}

/* 扑克样式 */
.poker-cards-list {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1.0em;
	position: relative;
	z-index: 10;
	color: var(--font-color);
}

.poker-cards-list .poker-card {
	padding: 0.3em;
	width: 3em;
	height: 4em;
	border: 3px solid var(--poker-border-color);
	border-radius: 5%;
	background-color: var(--poker-bg-default);
	color: var(--poker-bg-default);
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 0.2em;
}

.poker-cards-list .poker-card.active .poker-number {
	color: var(--font-color);
}

.poker-cards-list .poker-card.active .poker-decor {
	margin: auto;
	width: 2em;
	height: 2em;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: auto 100%;
}

.poker-cards-list .poker-card.active.poker-card1 {
	background-color: var(--poker-bg-color1);
}

.poker-cards-list .poker-card.active.poker-card1 .poker-decor {
	background-image: var(--decor1);
}

.poker-cards-list .poker-card.active.poker-card2 {
	background-color: var(--poker-bg-color2);
}

.poker-cards-list .poker-card.active.poker-card2 .poker-decor {
	background-image: var(--decor2);
}

.poker-cards-list .poker-card.active.poker-card3 {
	background-color: var(--poker-bg-color3);
}

.poker-cards-list .poker-card.active.poker-card3 .poker-decor {
	background-image: var(--decor3);
}

.poker-cards-list .poker-card.active.poker-card4 {
	background-color: var(--poker-bg-color4);
}

.poker-cards-list .poker-card.active.poker-card4 .poker-decor {
	background-image: var(--decor4);
}

/* 用户列表 */
.poker-user-list {
	width: 60em;
	height: 30em;
	position: absolute;
	z-index: 20;
}

.poker-user-list .poker-user-item {
	width: 10em;
	height: 5em;
	position: absolute;
	/* top: 50%;
	left: 50%; */
	transform: translateX(-50%) translateY(-50%);
}

/*弃牌样式  */
.poker-user-list .poker-user-item.abstention::before {
	display: block;
	content: "已弃牌";
	padding: .2em;
	z-index: 30;
	color: var(--font-color);
	background-color: #df4538;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
}



.poker-user-list .poker-user-item .poker-cards-list {
	gap: 0.4em;
}

.poker-user-list .poker-user-item .user-info {
	width: 10em;
	height: 3.5em;
	padding: 1em;
	color: var(--font-color);
	background-color: var(--info-panel-bg-color);
	border-radius: 0.5em;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	overflow: hidden;
	position: absolute;
	top: 50%;
	left: 0%;
	z-index: 20;
}

.poker-user-list .poker-user-item.rank .user-info::before {
	display: block;
	content: "";
	padding: 0.2em;
	border-bottom-right-radius: 0.5em;
	font-size: 12px;
	background-color: red;
	position: absolute;
	top: 0%;
	left: 0%;
}

.poker-user-list .poker-user-item.rank1 .user-info::before {
	content: "庄家";
}

.poker-user-list .poker-user-item.rank2 .user-info::before {
	content: "小盲";
}

.poker-user-list .poker-user-item.rank3 .user-info::before {
	content: "大盲";
}



.poker-user-list .poker-user-item .user-info .user-name {
	font-size: 16px;
	font-weight: bold;

}
/*用户的筹码 */

.poker-user-list .poker-user-item .user-info .user-chips{
	display: flex;
	flex-direction: row;
	justify-content: center;
	gap: 0.4em;
	position: absolute;
	right: 5%;
	bottom:15% ;
	/* transform: translateX(-50%) translateY(-50%); */
}

.poker-user-list .poker-user-item .user-info .user-chips .blind {
	width: 1em;
}

.poker-user-list .poker-user-item .user-info .user-chips .chips {
	margin-top: -1.2em;
	width: 1em;
	height: 1em;
	border-radius: 50%;
	border: 1px solid #fff;
}


.poker-user-list .poker-user-item .user-info .user-chips .big-blind .chips {
	background-color: var(--big-blind-bg-color);
}

.poker-user-list .poker-user-item .user-info .user-chips .small-blind .chips {
	background-color: var(--small-blind-bg-color);
}

/* 按钮样式 */

.btn-wrapper {
	width: fit-content;
	height: fit-content;
	display: flex;
	flex-direction: column;
	gap: 20px;
	position: absolute;
	right: 100px;
	bottom: 50%;
	transform: translateY(50%);
}


.btn-wrapper .btn {
	width: 100px;
	height: 40px;
	border: 1px solid var(--btn-border-color);
	border-radius: 4px;
	text-align: center;
	line-height: 40px;
	font-size: 16px;
	color: var(--font-color);
	cursor: pointer;
	user-select: none;
	box-shadow: var(--btn-box-shadow) transition: .2s;
}

.btn {
	transform: scale(1);
}

.btn:active {
	transform: scale(0.97);
}

/* 开始游戏 */
.btn.start-game {
	background-color: var(--btn-type1);
}

/* 跟注 */
.btn.user-call {
	background-color: var(--btn-type2);
}

/* 加注 */
.btn.user-raise {
	background-color: var(--btn-type3);
}

/* 放弃 */
.btn.user-abstention {
	background-color: var(--btn-type4);
}


/* 公布栏 */
.bulletin-board-wrapper {
	width: 20em;
	height: 17em;
	border-radius: 0.2em;
	background-color: var(--info-panel-bg-color);
	position: absolute;
	top: 2em;
	left: 2em;
}

.bulletin-board-wrapper .bulletin-board-title {
	width: 100%;
	height: 2.5em;
	font-size: 14px;
	color: var(--font-color);
	text-align: center;
	font-weight: bold;
	line-height: 2.5em;
	border-bottom: 1px solid rgba(0, 0, 0, 0.3);
}

.bulletin-board-wrapper .bulletin-board-info {
	padding: 0.5em 1em;

}

.bulletin-board-wrapper .bulletin-board-info .info-list {
	padding-right: 4px;
	width: 100%;
	height: 13.5em;
	overflow: auto;
}

.bulletin-board-wrapper .bulletin-board-info .info-list .info-item {
	margin-bottom: 0.4em;
	padding: 0.4em 0.4em 0.4em 2.5em;
	width: 100%;
	border-radius: 0.2em;
	color: var(--font-color);
	background-color: #666;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	position: relative;
	overflow: hidden;
}

.bulletin-board-wrapper .bulletin-board-info .info-list .info-item .info-name.rank::before {
	display: block;
	content: "";
	padding: 0.2em;
	border-bottom-right-radius: 0.5em;
	font-size: 12px;
	background-color: red;
	position: absolute;
	top: 0%;
	left: 0%;
}

.bulletin-board-wrapper .bulletin-board-info .info-list .info-item .info-name.rank1::before {
	content: "庄家";
}

.bulletin-board-wrapper .bulletin-board-info .info-list .info-item .info-name.rank2::before {
	content: "小盲";
}

.bulletin-board-wrapper .bulletin-board-info .info-list .info-item .info-name.rank3::before {
	content: "大盲";
}

.bulletin-board-wrapper .bulletin-board-info .info-list .info-item .info-total.type3 {
	color: var(--poker-bg-color3);
}

.bulletin-board-wrapper .bulletin-board-info .info-list .info-item .info-total.type4 {
	color: var(--poker-bg-color4);
}

.info-list::-webkit-scrollbar {
	width: 4px;
}

.info-list::-webkit-scrollbar-thumb {
	border-radius: 10px;
	box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2);
	background: rgba(0, 0, 0, 0.2);
}

.info-list::-webkit-scrollbar-track {
	box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2);
	border-radius: 0;
	background: rgba(0, 0, 0, 0.1);
}
JS代码部分
//扑克的点数
const pokerNumberArr = ['1', '2', '3', '4', '5', '6', '7', '8', '9', '10', 'J', 'Q', 'K']
//扑克花色 /* ♠ ♥ ♣ ♦ */
const pokerDecorArr = [1, 2, 3, 4]

// 总金额
let totalAmount = 0;
let totalAmountEl = document.querySelector(".total-amount");
//设置总金额的值
totalAmountEl.innerHTML = totalAmount

// 获取 牌桌的信息
let pokerCardsList = document.querySelector(".poker-cards-list");
const pokerNumber = 5; //桌面卡片数量
let pokerList = []; //扑克列表
addPokerCard(pokerNumber)


// 获取用户信息
let pokerUserList = document.querySelector(".poker-user-list");

//添加用户
let userList = []; //用户列表
const userNumber = 10; //人数
const angleIncrement = 360 / userNumber; // 计算角度增量
addUser(userNumber)


// 获取公示栏
let bulletinBboardInfoList = document.querySelector(".info-list");

// 开始游戏
let startGame = document.querySelector(".start-game");
//游戏开始标记
let startGameFlag = true;
// 庄家
let declarer = null;
let declarerIndex = null;
// 当前玩家
let currentUser = null;
// 当前玩家的索引
let currentUserIndex = null;
//下注执行顺序 从庄家开始进行
let userOrder = []

// 下注金额
let wagerTotal = 2
// 用户索引
let userIndex = null

// 列表索引
let userOrderIndex = 0
// 伦数
let number = 0

startGame.addEventListener("click", () => {
	if (startGameFlag) {
		startGameFlag = false;

		declarerIndex = Math.floor((Math.random() * userNumber));
		currentUserIndex = Math.floor((Math.random() * userNumber));

		// declarer = pokerUserList.children[declarerIndex];
		// declarer.classList.add("active");

		currentUser = pokerUserList.children[currentUserIndex];
		currentUser.querySelectorAll(".poker-card")[0].classList.add("active");
		currentUser.querySelectorAll(".poker-card")[1].classList.add("active");

		//重新开始游戏用户执行顺序
		userOrder = userOrder.concat(userList.splice(declarerIndex + 1)).concat(userList.splice(0,
			declarerIndex + 1));
		// 设置标记
		setMarker()
		// 从庄家用户开始检索
		startRaise(0)
	}
})

// 设置标记
function setMarker() {
	userOrder[userNumber - 1]['rank'] = 1 //庄
	userOrder[0]['rank'] = 2 //小盲
	userOrder[1]['rank'] = 3 //大盲
	pokerUserList.children[userOrder[userNumber - 1]['userIndex']].classList.add("rank", "rank1");
	pokerUserList.children[userOrder[0]['userIndex']].classList.add("rank", "rank2");
	pokerUserList.children[userOrder[1]['userIndex']].classList.add("rank", "rank3");
}


function startRaise(i) {
	for (i; i < userNumber; i++) {
		userOrderIndex = i
		let userInfo = userOrder[i]
		userIndex = userInfo.userIndex
		if (userInfo.status === 1) { //判断用户是否弃牌
			if (userIndex === currentUserIndex) { //是否是当前用户
				return
			} else { //机器人用户
				setUserTotal(i)
			}

			if (userIndex === declarerIndex) {
				userOrderIndex = 0
				number++;
				if (number === 1) {
					pokerCardsList.children[0].classList.add("active");
					pokerCardsList.children[1].classList.add("active");
					pokerCardsList.children[2].classList.add("active");
				} else if (number === 2) {
					pokerCardsList.children[3].classList.add("active");
				} else if (number === 3) {
					pokerCardsList.children[4].classList.add("active");
				} else {
					return;
				}

				startRaise(0)
				wagerTotal *= 2;
			}
		}
	}
}

// 玩家跟注
let userCall = document.querySelector(".user-call");
userCall.addEventListener("click", () => {
	if (currentUser && userIndex === currentUserIndex) {
		userOrder[userOrderIndex].wagerType = 2; //跟注
		setUserTotal(userOrderIndex)
		startRaise(userOrderIndex + 1)
	}
})

// 玩家加注
let userRaise = document.querySelector(".user-raise");
userRaise.addEventListener("click", () => {
	if (currentUser && userIndex === currentUserIndex) {
		wagerTotal *= 2;
		userOrder[userOrderIndex].wagerType = 3; //加注
		setUserTotal(userOrderIndex)
		startRaise(userOrderIndex + 1)
	}
})
// 玩家弃牌
let userAbstention = document.querySelector(".user-abstention");
userAbstention.addEventListener("click", () => {
	if (currentUser && userIndex === currentUserIndex) {
		userOrder[userOrderIndex].status = 2
		addBulletinBoardInfo(userOrder[userOrderIndex])
		pokerUserList.children[userIndex].classList.add('abstention')
		startRaise(userOrderIndex + 1)
	}
})

// 重新设置当前用户金额的信息
function setUserTotal(index) {
	userOrder[index].total = wagerTotal;
	let userTotal = pokerUserList.children[userIndex].querySelector('.user-total')
	userTotal.innerHTML = "$" + userOrder[index].total.toFixed(2)
	totalAmount += userOrder[index].total; //重新设置总金额
	totalAmountEl.innerHTML = totalAmount.toFixed(2)
	addBulletinBoardInfo(userOrder[index])
}


// 添加扑克
function addPokerCard(pokerNumber) {
	for (let i = 1; i <= pokerNumber; i++) {
		let poker = { //随机生成扑克牌信息
			"pokerNumber": pokerNumberArr[Math.floor((Math.random() * 13))],
			"pokerDecor": "poker-card" + pokerDecorArr[Math.floor((Math.random() * 4))]
		}
		pokerList.push(poker)
		let pokerCard = document.createElement("div")
		pokerCard.setAttribute("class", `poker-card ${poker.pokerDecor}`)
		pokerCard.innerHTML = setPokerInfo(poker)
		pokerCardsList.appendChild(pokerCard)
	}
}

// 设置扑克信息
function setPokerInfo(poker) {
	return `<div class="poker-number">${poker.pokerNumber}</div>
			<div class="poker-decor"></div>`
}

// 添加用户
function addUser(userNumber) {
	for (let i = 1; i <= userNumber; i++) {
		let poker1 = {
			"pokerNumber": pokerNumberArr[Math.floor((Math.random() * 13))],
			"pokerDecor": pokerDecorArr[Math.floor((Math.random() * 4))]
		}; //第一张扑克牌信息
		let poker2 = {
			"pokerNumber": pokerNumberArr[Math.floor((Math.random() * 13))],
			"pokerDecor": pokerDecorArr[Math.floor((Math.random() * 4))]
		}; //第一张扑克牌信息 //第二张扑克牌
		let pokerInfo = [poker1, poker2]; //扑克牌点数
		let userName = `用户${i}`; //用户姓名

		let total = 0; //下注金额

		totalAmount += total; //重新设置总金额
		totalAmountEl.innerHTML = totalAmount.toFixed(2)
		// 计算位置
		let angle = (i - 1) * angleIncrement; // 计算角度
		let radius = 50; // 设置半径,可以根据需要调整

		let positionTop = 50 + radius * Math.sin((angle * Math.PI) / 180);
		let positionLeft = 50 + radius * Math.cos((angle * Math.PI) / 180);

		let pokerUser = document.createElement("div")
		pokerUser.setAttribute("class", "poker-user-item")
		pokerUser.setAttribute("style", `top:${positionTop}%;left:${positionLeft}%;`)
		pokerUser.innerHTML = setUserInfo(pokerInfo, userName, total)
		pokerUserList.appendChild(pokerUser)
		userList.push({
			userId: i, //用户userId
			userIndex: (i - 1), //用户序号
			userName,
			pokerInfo,
			total,
			status: 1, //1.未弃牌 2.已弃牌
			wagerType: 1, //1.底注 2.跟注 3.加注
			rank: 0, //0.普通玩家 1.庄家 2.小盲 3.大盲
		})
	}
}

// 设置用户信息
function setUserInfo(pokerInfo, userName, total) {
	return `
	<div class="poker-cards-list">
		<div class="poker-card  poker-card${pokerInfo[0].pokerDecor}">
			<div class="poker-number">${pokerInfo[0].pokerNumber}</div>
			<div class="poker-decor"></div>
		</div>
		<div class="poker-card  poker-card${pokerInfo[1].pokerDecor}" >
			<div class="poker-number">${pokerInfo[1].pokerNumber}</div>
			<div class="poker-decor"></div>
		</div>
	</div>
	<div class="user-info">
		<div class="user-name">${userName}</div>
		<div class="user-total">$${total.toFixed(2)}</div>
		<div class="user-chips">
		<div class="blind big-blind">
				<div class="chips"></div>
				<div class="chips"></div>
				<div class="chips"></div>
				<div class="chips"></div>
			</div>
			<div class="blind small-blind">
				<div class="chips"></div>
				<div class="chips"></div>
			</div>
		</div>
	</div>`
}


// 添加 公布栏 信息
function addBulletinBoardInfo(userInfo) {
	let infoItem = document.createElement("div")
	infoItem.setAttribute("class", "info-item")
	infoItem.innerHTML = setBulletinBoardInfo(userInfo)
	bulletinBboardInfoList.appendChild(infoItem)
}

// 设置公布栏 信息
function setBulletinBoardInfo(userInfo) {
	let info = null;
	let className = ""; //类名
	let wagerType = +userInfo.wagerType //转为number类型  1.底注 2.跟注 3.加注
	let status = userInfo.status; //1.未弃牌 2.已弃牌
	let wagerTypeInfo = ["", "底注:", "跟注:", "加注:"]
	let statusInfo = ["", "未弃牌", "弃牌"]
	if (status === 1) {
		info = wagerTypeInfo[wagerType] + userInfo.total.toFixed(2);
	} else {
		info = statusInfo[status];
		wagerType = 4
	}
	className = userInfo.rank === 0 ? "" : `rank rank${userInfo.rank}`;
	return `<div class="info-name ${className}" >${userInfo.userName}</div>
			<div class="info-total type${wagerType}">${info}</div>`
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/297637.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

软件测试|深入学习 Docker Logs

简介 Docker 是一种流行的容器化技术&#xff0c;它能够帮助用户将应用程序及其依赖项打包成一个可移植的容器。Docker logs 是 Docker 提供的用于管理容器日志的命令&#xff0c;本文将深入学习 Docker logs 的使用和管理&#xff0c;帮助用户更好地监测和解决容器问题。 Do…

Python如何生成个性二维码

Python-生成个性二维码 一、问题描述 通过调用MyQR模块来实现生成个人所需二维码。 安装&#xff1a; pip install myqr 二、代码实现 1.普通二维码 from MyQR import myqr # 普通二维码 myqr.run(wordshttp://www.csdn.net/mayi0312,save_nameqrcode.png ) 效果图&#…

e2studio开发STHS34PF80人体存在传感器(1)----获取人体存在状态

e2studio开发STHS34PF80人体存在传感器.1--获取人体存在状态 概述视频教学样品申请完整代码下载主要特点硬件准备接口最小系统图新建工程工程模板保存工程路径芯片配置工程模板选择时钟设置UART配置UART属性配置设置e2studio堆栈e2studio的重定向printf设置R_SCI_UART_Open()函…

百度地图打点性能优化(海量点、mapv)

文章目录 百度地图打点性能优化&#xff08;海量点、mapv&#xff09;原因优化方法数据获取方面页面加载方面 参考资料 百度地图打点性能优化&#xff08;海量点、mapv&#xff09; 原因 在百度地图api中&#xff0c;默认的点是下图的红点 而这种点位比较多的时候&#xff0c…

关键字:super关键字

在 Java 中&#xff0c;super 关键字主要有以下两种用法&#xff1a; 在子类中调用父类的构造方法&#xff1a;当创建子类对象时&#xff0c;可以使用 super 关键字来显式调用父类的构造方法。这可以用于初始化父类的成员变量或执行父类的其他初始化操作。下面是一个示例代码&…

腾讯云2核2G3M服务器可以运行几个网站?

在探讨这个问题之前&#xff0c;我们需要先了解网站运行所需的基本资源。一个网站的运行通常需要以下几个方面的资源&#xff1a;CPU、内存、磁盘和网络。接下来&#xff0c;我们将分析这些资源在不同配置下的使用情况&#xff0c;以确定腾讯云2核2G3M服务器可以运行多少个网站…

并发(4)

目录 16.sychronized修饰方法在抛出异常时&#xff0c;会释放锁吗&#xff1f; 17.多个线程等待同一个sychronized锁的时候&#xff0c;JVM如何选择下一个获取锁的线程&#xff1f; 18.sychronized是公平锁吗&#xff1f; 19.volatile关键字的作用是什么&#xff1f; 20.vo…

基于日照时数计算逐日太阳辐射

基于日照时数计算逐日太阳辐射

分布式【Zookeeper】

1.1 ZooKeeper 是什么 ZooKeeper 是 Apache 的顶级项目。ZooKeeper 为分布式应用提供了高效且可靠的分布式协调服务&#xff0c;提供了诸如统一命名服务、配置管理和分布式锁等分布式的基础服务。在解决分布式数据一致性方面&#xff0c;ZooKeeper 并没有直接采用 Paxos 算法&…

安全加固之weblogic屏蔽T3协议

一、前言 开放weblogic控制台的7001端口&#xff0c;默认会开启T3协议服务&#xff0c;T3协议则会触发的Weblogic Server WLS Core Components中存在反序列化漏洞&#xff0c;攻击者可以发送构造的恶意T3协议数据&#xff0c;获取目标服务器权限。 本文介绍通过控制T3协议的访问…

vue3 的内置组件汇总

官方给出的说明&#xff1a; Fragment: Vue 3 组件不再要求有一个唯一的根节点&#xff0c;清除了很多无用的占位 div。Teleport: 允许组件渲染在别的元素内&#xff0c;主要开发弹窗组件的时候特别有用。Suspense: 异步组件&#xff0c;更方便开发有异步请求的组件。 一、fr…

商品砍价系统设计原理与实践:技术解析与注意事项

&#x1f604; 19年之后由于某些原因断更了三年&#xff0c;23年重新扬帆起航&#xff0c;推出更多优质博文&#xff0c;希望大家多多支持&#xff5e; &#x1f337; 古之立大事者&#xff0c;不惟有超世之才&#xff0c;亦必有坚忍不拔之志 &#x1f390; 个人CSND主页——Mi…

SpringBoot 调用mybatis报错:Invalid bound statement (not found):

启动SpringBoot报错&#xff1a;Invalid bound statement (not found): 参考此文排查 命中了第6条 记录一手坑爹的Invalid bound statement (not found)&#xff08;六个方面&#xff09; mapper文件路径配置错误 订正以后 问题解决

GLSL着色器入门(持续更新中...)

目录 第一章&#xff1a;OpenGL works with triangles 第二章&#xff1a; Parallel Processing 第章 推荐来自b站的课程004 GLSL is not Javascript_哔哩哔哩_bilibili 第一章&#xff1a;OpenGL works with triangles 当我们谈论GLSL着色器时&#xff0c;其实就是在说怎么…

开发个小破软件——网址导航,解压就能用

网址导航 网站导航也称链接目录&#xff0c;将网站地址或系统地址分类&#xff0c;以列表、图文等形式呈现&#xff0c;帮助快速找到需要的地址。 应用场景 高效查找&#xff1a;网址导航是很好的入口&#xff0c;通过分类清晰的网站推荐&#xff0c;可以迅速访问网站资源。…

数据的创建、调用、修改、删除存储过程,以及第一类丢失更新(回滚丢失)和 第二类丢失更新(覆盖丢失/两次更新问题)

数据的创建存储过程、调用存储过程、修改存储过程、删除存储过程&#xff0c;以及第一类丢失更新&#xff08;回滚丢失&#xff09;和 第二类丢失更新&#xff08;覆盖丢失/两次更新问题&#xff09; 文章目录 一、创建存储的语法二、调用存储过程三、修改存储过程四、删除存储…

【python实战】python一行代码,实现文件共享服务器

一行代码实现文件共享 在一个局域网内&#xff0c;需要共享一个文件夹里内容。 我们可以在任意一台有python环境的电脑上&#xff0c;迅速架起一个http协议的服务&#xff0c;然后将文件夹里的文件内容共享出来。是的仅仅需要一行代码 就是这么简单 把电脑的相关项目文件通…

Python中的有序字典是什么

有序字典 一、简介 Python中的字典的特性&#xff1a;无序性。 有序字典和通常字典类似&#xff0c;只是它可以记录元素插入其中的顺序&#xff0c;而一般字典是会以任意的顺序迭代的。 二、普通字典 #! /usr/bin/env python3 # -*- coding:utf-8 -*- d1 {} d1[a] A d1[b…

【Unity】 HTFramework框架(四十七)编辑器日志中使用超链接的技巧

更新日期&#xff1a;2024年1月3日。 Github源码&#xff1a;[点我获取源码] Gitee源码&#xff1a;[点我获取源码] 索引 日志中使用超链接超链接-网络地址超链接-本地地址超链接-项目资源文件超链接-脚本对象 日志中使用超链接 在编辑器控制台Console中的日志是支持富文本的&…

使用Spring Cache优化数据库访问

使用Spring Cache优化数据库访问 在这篇博客中&#xff0c;我们将学习如何使用Spring Cache来优化数据库访问&#xff0c;提高系统性能。我们将创建一个简单的图书管理应用作为示例&#xff0c;并演示如何通过缓存减少对数据库的频繁查询。 1. 项目结构 首先&#xff0c;我们…