⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 auth_userpasswd.c

📁 这是一个同样来自贝尔实验室的和UNIX有着渊源的操作系统, 其简洁的设计和实现易于我们学习和理解
💻 C
字号:
#include <u.h>#include <libc.h>#include <auth.h>#include <authsrv.h>#include "authlocal.h"/* * compute the proper response.  We encrypt the ascii of * challenge number, with trailing binary zero fill. * This process was derived empirically. * this was copied from inet's guard. */static voidnetresp(char *key, long chal, char *answer){	uchar buf[8];	memset(buf, 0, 8);	sprint((char *)buf, "%lud", chal);	if(encrypt(key, buf, 8) < 0)		abort();	chal = (buf[0]<<24)+(buf[1]<<16)+(buf[2]<<8)+buf[3];	sprint(answer, "%.8lux", chal);}AuthInfo*auth_userpasswd(char *user, char *passwd){	char key[DESKEYLEN], resp[16];	AuthInfo *ai;	Chalstate *ch;	/*	 * Probably we should have a factotum protocol	 * to check a raw password.  For now, we use	 * p9cr, which is simplest to speak.	 */	if((ch = auth_challenge("user=%q proto=p9cr role=server", user)) == nil)		return nil;	passtokey(key, passwd);	netresp(key, atol(ch->chal), resp);	memset(key, 0, sizeof key);	ch->resp = resp;	ch->nresp = strlen(resp);	ai = auth_response(ch);	auth_freechal(ch);	return ai;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -