summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorin2 <in2@63ad8ddf-47c3-0310-b6dd-a9e9d9715204>2003-06-21 13:50:47 +0800
committerin2 <in2@63ad8ddf-47c3-0310-b6dd-a9e9d9715204>2003-06-21 13:50:47 +0800
commitbe51b17000ce97ad50c2ef21e0d8050c42b4dd8a (patch)
tree0b7ba5e59bdcf6f6349abc59740955da2654790f
parent19e626a9f2b9511a2bc5f632cd80c5b3a9c1902b (diff)
downloadpttbbs-be51b17000ce97ad50c2ef21e0d8050c42b4dd8a.tar
pttbbs-be51b17000ce97ad50c2ef21e0d8050c42b4dd8a.tar.gz
pttbbs-be51b17000ce97ad50c2ef21e0d8050c42b4dd8a.tar.bz2
pttbbs-be51b17000ce97ad50c2ef21e0d8050c42b4dd8a.tar.lz
pttbbs-be51b17000ce97ad50c2ef21e0d8050c42b4dd8a.tar.xz
pttbbs-be51b17000ce97ad50c2ef21e0d8050c42b4dd8a.tar.zst
pttbbs-be51b17000ce97ad50c2ef21e0d8050c42b4dd8a.zip
register
git-svn-id: http://opensvn.csie.org/pttbbs/pttbbs/trunk/pttbbs@952 63ad8ddf-47c3-0310-b6dd-a9e9d9715204
-rw-r--r--mbbsd/user.c88
1 files changed, 41 insertions, 47 deletions
diff --git a/mbbsd/user.c b/mbbsd/user.c
index 33288f0a..9031107e 100644
--- a/mbbsd/user.c
+++ b/mbbsd/user.c
@@ -1,4 +1,4 @@
-/* $Id: user.c,v 1.61 2003/06/02 01:43:16 in2 Exp $ */
+/* $Id: user.c,v 1.62 2003/06/21 05:50:47 in2 Exp $ */
#include "bbs.h"
static char *sex[8] = {
@@ -900,7 +900,7 @@ getregcode(char *buf)
}
static int
-isvaildemail(char *email)
+isvalidemail(char *email)
{
FILE *fp;
char buf[128], *c;
@@ -971,7 +971,7 @@ toregister(char *email, char *genbuf, char *phone, char *career, char fore,
break;
#ifdef HAVEMOBILE
else if (strcmp(email, "m") == 0 || strcmp(email, "M") == 0) {
- if (isvaildmobile(mobile)) {
+ if (isvalidmobile(mobile)) {
char yn[3];
getdata(16, 0, "請再次確認您輸入的手機號碼正確嘛? [y/N]",
yn, sizeof(yn), LCECHO);
@@ -985,7 +985,7 @@ toregister(char *email, char *genbuf, char *phone, char *career, char fore,
}
#endif
- else if (isvaildemail(email)) {
+ else if (isvalidemail(email)) {
char yn[3];
getdata(16, 0, "請再次確認您輸入的 E-Mail 位置正確嘛? [y/N]",
yn, sizeof(yn), LCECHO);
@@ -1045,24 +1045,32 @@ toregister(char *email, char *genbuf, char *phone, char *career, char fore,
}
}
-static char *isvaildname(char *rname)
+static int HaveRejectStr(char *s, char **rej)
{
+ int i;
+ char *rejectstr[] =
+ {"幹", "阿", "ㄚ", "不", "你媽", "某", "笨", "呆", "..", "xx",
+ "你管", "管我", NULL};
+
+ if( rej != NULL )
+ for( i = 0 ; rej[i] != NULL ; ++i )
+ if( strstr(s, rej[i]) )
+ return 1;
+
+ for( i = 0 ; rejectstr[i] != NULL ; ++i )
+ if( strstr(s, rejectstr[i]) )
+ return 1;
+ return 0;
+}
+
+static char *isvalidname(char *rname)
+{
+ char *rejectstr[] =
+ {"肥", "胖", "豬頭", "小白", "小明", "路人", "老王", "老李", "寶貝",
+ "先生", "師哥", "老頭", "小姊", "小姐", "美女", "小妹", NULL};
if( removespace(rname) && rname[0] < 0 &&
strlen(rname) >= 4 &&
- !strstr(rname, "幹") && !strstr(rname, "肥") &&
- !strstr(rname, "胖") && !strstr(rname, "笨") &&
- !strstr(rname, "阿") && !strstr(rname, "某") &&
- !strstr(rname, "ㄚ") && !strstr(rname, "..") &&
- !strstr(rname, "呆") &&
-
- !strstr(rname, "美女") && !strstr(rname, "帥哥") &&
- !strstr(rname, "先生") && !strstr(rname, "小姐") &&
- !strstr(rname, "老頭") && !strstr(rname, "豬頭") &&
- !strstr(rname, "寶貝") && !strstr(rname, "小白") &&
- !strstr(rname, "小明") && !strstr(rname, "小妹") &&
- !strstr(rname, "路人") && !strstr(rname, "不說") &&
- !strstr(rname, "不知") && !strstr(rname, "你媽") &&
-
+ !HaveRejectStr(rname, rejectstr) &&
strncmp(rname, "小", 2) != 0 && //起頭是「小」
strncmp(rname, "我是", 4) != 0 && //起頭是「我是」
!(strlen(rname) == 4 && strncmp(&rname[2], "兒", 2) == 0) &&
@@ -1071,44 +1079,30 @@ static char *isvaildname(char *rname)
return "您的輸入不正確";
}
-static char *isvaildcareer(char *career)
+static char *isvalidcareer(char *career)
{
- if (!(removespace(career) && career[0] < 0
- && strlen(career) >= 6) ||
- strcmp(career, "家裡") == 0 ||
- strstr(career, "幹") != NULL ||
- strstr(career, "不知") != NULL ||
- strstr(career, "不說") != NULL ||
- strstr(career, "你管") != NULL ||
- strstr(career, "管我") != NULL ||
- strstr(career, "某") != NULL ) {
+ char *rejectstr[] = {NULL};
+ if (!(removespace(career) && career[0] < 0 && strlen(career) >= 6) ||
+ strcmp(career, "家裡") == 0 || HaveRejectStr(career, rejectstr) )
return "您的輸入不正確";
- }
if (strcmp(&career[strlen(career) - 2], "大") == 0 ||
strcmp(&career[strlen(career) - 4], "大學") == 0 )
return "麻煩請加學校系所";
return NULL;
}
-static char *isvaildaddr(char *addr)
+static char *isvalidaddr(char *addr)
{
+ char *rejectstr[] =
+ {"地球", "銀河", "火星", NULL};
+
if (!removespace(addr) || addr[0] > 0 || strlen(addr) < 15)
return "這個地址並不合法";
if (strstr(addr, "信箱") != NULL || strstr(addr, "郵政") != NULL)
return "抱歉我們不接受郵政信箱";
if ((strstr(addr, "市") == NULL && strstr(addr, "巿") == NULL &&
strstr(addr, "縣") == NULL && strstr(addr, "室") == NULL) ||
- strstr(addr, "地球") != NULL ||
- strstr(addr, "銀河") != NULL ||
- strstr(addr, "火星") != NULL ||
- strstr(addr, "不知") != NULL ||
- strstr(addr, "不說") != NULL ||
- strstr(addr, "你管") != NULL ||
- strstr(addr, "管我") != NULL ||
- strstr(addr, "某") != NULL ||
- strstr(addr, "..") != NULL ||
- strstr(addr, "xx") != NULL ||
- strstr(addr, "幹") != NULL ||
+ HaveRejectStr(addr, rejectstr) ||
strcmp(&addr[strlen(addr) - 2], "段") == 0 ||
strcmp(&addr[strlen(addr) - 2], "路") == 0 ||
strcmp(&addr[strlen(addr) - 2], "巷") == 0 ||
@@ -1118,7 +1112,7 @@ static char *isvaildaddr(char *addr)
return NULL;
}
-static char *isvaildphone(char *phone)
+static char *isvalidphone(char *phone)
{
if (strstr(phone, "(") || strstr(phone, ")") || strstr(phone, "-")){
return "電話請不加 ( ) - 符號";
@@ -1282,7 +1276,7 @@ u_register(void)
#endif
while (1) {
getfield(8, "請用中文", "真實姓名", rname, 20);
- if( (errcode = isvaildname(rname)) == NULL )
+ if( (errcode = isvalidname(rname)) == NULL )
break;
else
vmsg(errcode);
@@ -1294,7 +1288,7 @@ u_register(void)
while (1) {
getfield(9, "學校(含\033[1;33m系所年級\033[m)或單位職稱",
"服務單位", career, 40);
- if( (errcode = isvaildcareer(career)) == NULL )
+ if( (errcode = isvalidcareer(career)) == NULL )
break;
else
vmsg(errcode);
@@ -1303,14 +1297,14 @@ u_register(void)
getfield(11, "含\033[1;33m縣市\033[m及門寢號碼"
"(台北請加\033[1;33m行政區\033[m)",
"目前住址", addr, 50);
- if( (errcode = isvaildaddr(addr)) == NULL )
+ if( (errcode = isvalidaddr(addr)) == NULL )
break;
else
vmsg(errcode);
}
while (1) {
getfield(13, "不加-(), 包括長途區號", "連絡電話", phone, 11);
- if( (errcode = isvaildphone(phone)) == NULL )
+ if( (errcode = isvalidphone(phone)) == NULL )
break;
else
vmsg(errcode);