课程管理系统数据库代码(学生课程管理系统数据库)

http://www.itjxue.com  2023-03-17 19:41  来源:未知  点击次数: 

如何用php代码实现一个学生管理系统包括学生管理课程管理

这个不是一两句话能说清楚的,也不清楚你现在水平在什么位置。

不过我说一下,需要的技术和方法步骤。

首先,你要会html css 最好还会javascript

然后是php mysql

这五种最基本的技术。

然后:

1.先用html+css写好你程序用到的网站界面。

2.设计数据库,比如 学生表,课程表,班级表,教师表等等

3.用php写后台,如登陆后台,之后就是对数据库增删改查。

用C语言编写数据库管理系统的代码 !!急求!!!

老兄,你在csdn、pudn上搜索下现成的吧。

你这个是大学的作业吧?日本有个开源的tokyo cabinet应该符合你的要求,而且远远超过,它本身就是NoSQL的数据库……

c语言程序设计课程设计 图书管理系统 求原代码

高级语言程序设计(2)课程设计

???

一 程序设计说明书

【设计题目】 图书馆借阅管理

【问题描述】图书馆,适合用C++面向对象的功能来描述。图书馆管理系统分为借书、还书、图书管理和读者服务等四个部分。设计一个读者类Reader,记录每个读者基本信息;读者库类Rdatabase,记录所有读者信息;图书类Book, 记录每本书的基本信息;图书库类Bdatabase, 记录所有图书信息。

【基本要求】

1读者库类RDatabase中,其构造函数中,将read.txt文件中所有读入读者记录rede[]中。处理完毕,在析构函数中将read[]中的所有未删记录写入到read.txt中。

2图书库类BDatabase中,其构造函数中,将book.txt文件中所有读入图书记录book[]中。处理完毕,在析构函数中将book[]中的所有未删记录写入到book.txt中。

3 利用构造函数完成读者和图书数据初始化,完成内存分配。程序结束前,析构函数完成所申请的堆内存空间。

4 编写主函数,对所编写的矩阵类进行全面测试。要求用户界面采用菜单方式。测试中需要读者和图书数据通过I/O流从磁盘文件读入,同时显示在屏幕上。得到的数据通过I/O流写入磁盘文件保存,同时显示在屏幕上。

5 源程序中要有充分的注释,报告中要有详细的流程图和文字材料。

【类的设计】

该程序包含了四个类,如下:

1.Reader类,有读者的基本管理功能,具有以下私有数据:

int tag;//删除标记 1:已删;0:未删

int no;//读者编号

char name[10];//读者姓名

int borbook[Maxbor];//所借图书

2.读者库类Rdatabase, 具有以下私有数据:

int top;//读者记录指针

Reader read[Maxr];//读者记录

3.图书库类Book,有一本图书的基本功能,有以下私有数据:

int tag;//删除标记 1:已删;0:未删

int no;//图书编号

char name[20];//书名

int onshelf;//是否在架 1在架 0已借

4.图书库类BDatabase,有以下私有数据:

int top;//图书记录指针

Book book[Maxb];//图书记录

【特殊函数的设计说明】

构造函数

1.Reader类中构造函数Reader(),初始化函数;

2.读者库类RDatabase中,其构造函数Rdatabase(),将read.txt文件中所有读入读者记录rede[]中。

3.Book类中构造函数Book(),初始化函数;

4.图书库类BDatabase中,其构造函数中,将book.txt文件中所有读入图书记录book[]中。

?

拷贝构造函数

Reader类中的拷贝构造函数将getname()的返回值读者姓名拷贝到setname()中,Book类中的拷贝构造函数将getname()函数的返回值图书名拷贝到图书名设置函数setname()中。

?

析构函数

1.读者库类RDatabase中,其析构函数~Rdatabase(),将read[]中的所有未删记录写入到read.txt中;

2.图书库类BDatabase中,其析构函数~Bdatabase(),将book[]中的所有未删记录写入到book.txt中。

?

运算符重载

重载了“=”,当比较读者编号和图书编号时,重载;重载位运算符“〈〈”和“〉〉”等。

?

【主要函数算法流程图】

?

【程序的使用方法】

1.进入操作页面,按提示操作;

2.首先,新增图书和读者信息,之后就可以对以存在的信息进行操作;

3.操作当中,可以随时增加,更改和删除图书或读者信息;

4.当选择退出时,进行清屏。

?

二 程序上机调试报告

【语法错误及其排除】

1.在敲程序时,有很多拼写错误,例好多处把Readdata()误打Readdate();结束的分号,在不同的输入法状态下输入,这些小错误刚开始很难发现,不过有了经验,就很容易了。

2.创建新的构造函数时,使用出现了错误。重载构造函数要注意函数的访问权限,结果就不会出现错误。

【算法错误及其排除】

1.读者类中借书操作函数中,采用循环语句时判断读者已借图书量时for(int i=0;iMaxbor;i++)误写为for(int i=1;iMaxbor;i++),使循环发生错误。

2.指针使用错误,指针b和r混淆,导致编译错误得到“error C2660: 'retbook' : function does not take 1 parameters”错误报告。

三 程序测试结果

【收获及体会】

除了课堂外,课程设计是最能学到东西的,最考验人的。在做课程设计这段时间,时刻都感觉自己有好多不懂,要学的太多了!经过这次课程设计,让我对C++这门语言有了更深的认识,操作能力有了提高。要想得到敲的代码运行出来后的满足感,需要耐心细心,毅力以及充沛的体力。只有经过多次编辑,多次编译,再多次运行,才能编写出更好的程序,有时候需要多次的更正才达到所要的运行结果。学习编程,需要多揣摩,实践,实践,再实践,编程技能才能更上一层楼,此外还得多向高手请教!

【源程序代码】

//********************

//图书馆借阅管理

//班级:

//学号:

//姓名:

//********************

#includeiostream.h

#includeiomanip.h

#includestring.h

#includefstream.h

const int Maxr=1000;//最多的读者

const int Maxb=10000;//最多的图书

const int Maxbor=8;//每位读者最多借8本书

class Reader //读者类

{

int tag;//删除标记 1已删;0未删

int no;//读者编号

char name[10];//读者姓名

int borbook[Maxbor];//所借图书

public :

Reader(){}//构造函数

char *getname(){return name;}//获取读者姓名

int gettag(){return tag;}//获取删除标记

int getno(){return no;}//获取读者编号

void setname(char na[])//设置读者姓名

{

strcpy(name,na);

}

void delbook(){tag=1;}//设置删除标记

void addreader(int n,char *na)//增加读者

{

tag=0;

no=n;

strcpy(name,na);

for(int i=0;iMaxbor;i++)

borbook[i]=0;

}

void borrowbook(int bookid)//借书操作

{

for(int i=0;iMaxbor;i++)

{

if(borbook[i]==0)

{

borbook[i]=bookid;

}

}

}

int retbook(int bookid)//还书操作

{

for(int i=0;iMaxbor;i++)

{

if (borbook[i]==bookid)

{

borbook[i]=0;

return 1;

}

}

return 0;

}

void disp()//输出读者信息

{

coutsetw(5)nosetw(10)name"借书编号:";

for(int i=0;i,Maxbor;i++)

if(borbook[i]!=0)

coutborbook[i]endl;

}

};

?

class RDatabase//读者库类

{

int top;//读者记录指针

Reader read[Maxr];//读者记录

public:

RDatabase()//构造函数,将reader.txt读到read[]中

{

Reader s;

top=-1;

fstream file("reader.txt",ios::in);

while(1)

{

file.read((char*)s,sizeof(s));

if(!file)break;

top++;

read[top]=s;

}

file.close();

}

void clear()//删除所有读者信息

{

top=-1;

}

int addreader(int n,char *na)//添加读者,检查是否已存在

{

Reader *p=query(n);

if(p==NULL)

{

top++;

read[top].addreader(n,na);

return 1;

}

return 0;

}

Reader*query(int readerid)//按编号查找

{

for(int i=0;i=top;i++)

if(read[i].getno()==readeridread[i].gettag==0)

return read[i];

return NULL;

}

void disp()//删除读者所有信息

{

for(int i=0;i=top;i++)

read[i].disp();

}

void readerdata();//读者库维护

~RDatabase()//析构函数,将read[]写入reader.txt文件中

{

fstream file("reader.txt",ios::out);

for(int i=0;i=top;i++)

if(read[i].gettag()==0)

file.write((char*)read[i],sizeof(read[i]));

file.close();

}

};

void RDatabase::readerdata()

{

int choice=1;

char rname[20];

int readerid;

Reader*r;

while(choice!=0)

{

cout"读者服务 1新增 2更该 3删除 4查找 5显示 6全删 0退出"endl;

cinchoice;

switch(choice)

{

case 1:

cout"请输入读者编号:";

cinreaderid;

cout"读入读者姓名:";

cinrname;

addreader(readerid,rname);

break;

case 2:

cout"请输入读者编号:";

cinreaderid;

r=query(readerid);

if(r==NULL)

{

cout"读者不存在"endl;

break;

}

cout"请输入新读者姓名:";

cinrname;

r-setname(rname);

break;

case 3:

cout"请输入读者编号:";

cinreaderid;

r=query(readerid);

if(r==NULL)

{

cout"读者不存在"endl;

break;

}

r-delbook();

break;

case 4:

cout"请输入读者编号:";

cinreaderid;

r=query(readerid);

if(r==NULL)

{

cout"该读者编号不存在"endl;

break;

}

case 5:

disp();

break;

case 6:

clear();

break;

}

}

}

?

class Book//图书类

{

int tag;//删除标记 1:已删;0:未删

int no;//图书编号

char name[20];//书名

int onshelf;//是否在架 1在架 0已借

public:

Book(){}

char*getname(){return name;}//获取读者姓名

int getno(){return no;}//获取图书编号

int gettag(){return tag;}//获取删除标记

void setname(char na[])//设置书名

{

strcpy(name,na);

}

void delbook(){tag=1;}//删除图书

void addbook(int n,char*na)//增加图书

{

tag=0;

no=n;

strcpy(name,na);

onshelf=1;

}

int borrowbook()//借书操作

{

if(onshelf==1)

{

onshelf=0;

return 1;

}

return 0;

}

void retbook()//还书操作

{

onshelf=1;

}

void disp()//输出图书

{

coutsetw(6)nosetw(18)namesetw(10)(onshelf==1?"在架":"已借")endl;

}

};

?

class BDatabase//图书库类

{

int top;//图书记录指针

Book book[Maxb];//图书记录

public:

BDatabase()//构造函数,将book.txt读到book[]中

{

Book b;

top=-1;

fstream file("book.txt",ios::in);

while(1)

{

file.read((char*)b,sizeof(b));

if(!file)break;

top++;

book[top]=b;

}

file.close();

}

void clear()//全删

{

top=-1;

}

int addbook(int n,char*na)//增加图书

{

Book*p=query(n);

if(p==NULL)

{

top++;

book[top].addbook(n,na);

return 1;

}

cout"新增成功!"endl;

}

Book*query(int bookid)//查找图书

{

for(int i=0;i=top;i++)

if(book[i].getno()==bookidbook[i].gettag()==0)

return NULL;

}

void bookdata();//图书库维护

void disp()

{

for(int i=0;i=top;i++)

if(book[i].gettag()==0)

book[i].disp();

}

~BDatabase()//析构函数,将book[]写入book.txt文件中

{

fstream file("book.txt",ios::out);

for (int i=0;i=top;i++)

if(book[i].gettag()==0)

file.write((char*)book[i],sizeof(book[i]));

file.close();

}

};

void BDatabase::bookdata()

{

int choice;

char bname[40];

int bookid;

Book *b;

while(choice!=0)

{

cout"图书管理 1新增 2更该 3删除 4查找 5显示 6全删 0退出"endl;

cinchoice;

switch(choice)

{

case 1:

cout"输入图书编号:";

cinbookid;

cout"输入图书书名:";

cinbname;

addbook(bookid,bname);

break;

case 2:

cout"输入图书编号:";

cinbookid;

b=query(bookid);

if(b==NULL)

{

cout"该图书不存在"endl;

break;

}

cout"输入新书名:";

cinbname;

b-setname(bname);

cout"更名成功!"endl;

break;

case 3:

cout"输入图书编号:";

cinbookid;

b=query(bookid);

if(b==NULL)

{

cout"该图书不存在!"endl;

break;

}

b-delbook();

break;

case 4:

cout"请输入图书编号:";

cinbookid;

b=query(bookid);

if(b==NULL)

{

cout"该书不存在!"endl;

break;

}

b-disp();

break;

case 5:

disp();

break;

case 6:

clear();

break;

}

}

}

?

void main()

{

int choice=1,bookid,readerid;

RDatabase ReaderDB;

Reader *r;

BDatabase BookDB;

Book *b;

while(choice!=0)

{

cout" 1借书????? "endl;

cout" 2还书????? "endl;

cout" 3图书维护? "endl;

cout" 4读者维护? "endl;

cout" 0离开????? "endl;

cinchoice;

switch(choice)

{

case 1:

cout"借书,请输入读者编号:";

cinreaderid;

cout"图书编号:";

cinbookid;

r=ReaderDB.query(readerid);

if(r==NULL)

{

cout"哈哈,借书成功!";

break;

}

b=BookDB.query(bookid);

if(b==NULL)

{

cout"不存在该书!"endl;

break;

}

if(b-borrowbook()==0)

{

cout"该书已借"endl;

break;

}

r-borrowbook(b-getno());

break;

cout"借书成功!"endl;

case 2:

cout"还书,请输入读者编号:";

cinreaderid;

cout"请输入图书编号;";

cinbookid;

r=ReaderDB.query(readerid);

if(r==NULL)

{

cout"不存在该读者!"endl;

break;

}

b-retbook();

r-retbook(b-getno());

break;

cout"还书成功!"endl;

case 3:

BookDB.bookdata();

break;

case 4:

ReaderDB.readerdata();

break;

}

}

}

【输出结果】

1借书

2还书

3图书管理

4读者服务

0退出

3

图书管理 1新增 2更该 3删除 4查找 5显示 6全删 0退出

1

输入图书编号:1111

输入图书书名:武林外传

新增成功!

图书管理 1新增 2更该 3删除 4查找 5显示 6全删 0退出

1

输入图书编号:2222

输入图书书名:今夜无眠

新增成功!

图书管理 1新增 2更该 3删除 4查找 5显示 6全删 0退出

1借书

2还书

3图书管理

4读者服务

0退出

4

读者服务 1新增 2更该 3删除 4查找 5显示 6全删 0退出

1

请输入读者编号:001

读入读者姓名:周强

读者服务 1新增 2更该 3删除 4查找 5显示 6全删 0退出

1借书

2还书

3图书管理

4读者服务

0退出

1

借书,请输入读者编号:001

图书编号:1111

哈哈,借书成功! 1借书

2还书

3图书管理

4读者服务

0退出

2

还书,请输入读者编号:001

请输入图书编号;1111

还书成功!

1借书

2还书

3图书管理

4读者服务

0退出

3

图书管理 1新增 2更该 3删除 4查找 5显示 6全删 0退出

2

输入图书编号:2222

输入新书名:金庸全集

更名成功!

Press any key to continue

课程设计仓库管理系统的数据库制作

数据库原理及应用课程设计

一、课程设计的目的

《数据库原理及应用》课程设计是计算机科学与技术专业集中实践性环节之一,是学习完《数据库原理及应用》课程后进行的一次全面的综合练习。本课程设计主要在于加深学生对数据库基础理论和基本知识的理解,掌握数据库应用系统设计开发的基本方法,达到进一步使学生综合运用所学知识和增强实际动手能力的目的。

二、课程设计的任务与要求

要求学生根据自身对题目的理解情况,从给定的设计题目中选择一个,以MS SQL Server作为后台数据库平台,以PowerBuilder作为前台开发工具,完成一个小型数据库应用系统的系统的分析、设计和开发。

三、课程设计说明书

仓储管理系统

对于一个以生产或经营产品为主要业务的单位来说,仓库管理系统至关重要。高效方便的仓库管理系统,可以为生产经营提供坚强的后盾和有力的支持。效率低下甚至是混乱不堪的仓库管理系统,无疑会成为企业健康发展的拖累甚至是枷锁。使企业发展动力不足。本次数据库设计实现了仓库管理的高效化、电子化。通过本系统可以方便地实现仓库管理中的货物登记、出库入库等操作,使仓库管理井井有条。

1系统需求分析

1.1系统功能需求分析

仓库管理系统主要实现对库存商品的管理,对商品出库、入库的管理,和对仓库管理系统维护的功能。具体要实现的功能包括:

1)库存商品管理

查看数据库中商品的名称、编号、单价等信息。

2)商品出库、入库管理

入库、出库单纪录本次入库、出库的货物名称、数量,入库、出库的时间、商品单价以及总价,入库、出库的经手人等。

3)商品的查询

输入商品的编号或者商品的名称查询信息

4)用户管理

用户可以修改登录密码

1. 2数据需求分析

1.员工(ID ,姓名,密码,权限)

2.商品(商品名,商品编号,所属类,单价)

3.出货表(商品名,商品编号,数量,总价,经手人)

4.入货表(商品名,商品编号,数量,总价,经手人)

5.查询(商品名,商品编号,数量,单价)

根据上面的关系我们需要的数据基本上就上面所列出的数据。

2 系统总体设计

1)库存商品管理

查看数据库中商品的名称、编号、单价等信息。

2)商品出库、入库管理

入库、出库单纪录本次入库、出库的货物名称、数量,入库、出库的时间、商品单价以及总价,入库、出库的经手人等。

3)商品的查询

输入商品的编号或者商品的名称查询信息

4)用户管理

用户可以修改登录密码

2.1系统总体结构设计

2.2.1 E-R图

2.2.2 关系模式

1.员工(ID ,姓名,密码,权限)

2.商品(商品名,商品编号,所属类,单价)

3.出货表(商品名,商品编号,数量,总价,经手人)

4.入货表(商品名,商品编号,数量,总价,经手人)

5.查询(商品名,商品编号,数量,单价)

2.2.3 数据表

“员工信息表”“商品信息表”“出货单”“进货单”的主键分别是:ID、商品编号、商品编号、商品编号。

员工信息表

商品信息表

出货单

进货单

3.系统实施

工作界面PB9.0,以下是我制作过程和运行中的一些截图:

首先建立PB与SQL的数据链接:如果链接不成功,返回对以话框“数据库连接错误,经检查后再试!”

然后点Preview选项会弹出如下窗口:

一、 工作界面截图:

分别建有:workspace、application、windows、dw_、da_等。

工作时检测连接数据库是否正常的程序代码:

// Profile q

SQLCA.DBMS = "ODBC"

SQLCA.AutoCommit = False

SQLCA.DBParm = "ConnectString='DSN=仓库;UID=;PWD='"

connect;

open(w_enter)

二、 运行结果的截图:

这个是我运行后的第一个用户界面,在界面中输入管理员ID和密码。我的管理员ID 和密码分别为 1,123.点击确定进入menu下一界面。

若ID和密码分别输入1,1234,则跳出以下界面:

确定按钮所对应的代码如下:

//定义两个变量

string password,userid

password=sle_2.text

//检索用户名和密码记录

SELECT "员工信息表". "ID",

"员工信息表"."密码"

INTO :userid,

:password

FROM "员工信息表"

WHERE "员工信息表"."ID" =:sle_1.text and "员工信息表"."密码" =:sle_2.text;

//判断用户输入的用户名是否正确

if sqlca.sqlcode0 then

messagebox("错误!","ID或密码错误,请重新输入!",exclamation!,ok!,2)

else

messagebox("通过验证!","ID和密码正确,欢迎您使用本系统!",Information!,ok!,2)

open(w_main)

close(w_enter)

end if

取消按钮所对应的代码如下:

close(parent)

//关闭登录窗口

三、 menu界面的截图:

在本界面中我们通过点击菜单栏上的不同管理按钮来实现管理和操作的功能。

进货—进货单

出货—出货单

库存—蔬菜类

—水产类

—肉类

系统维护—修改密码

查询

四、 进货的截图如下:

在本界面中,操作员可以输入进货信息

五、 进货的截图如下:

在本界面中,操作员可以输入出货信息

六、本界面是实现用户更改自己的密码的界面

用户在登陆后根据上面的提示可以更改自己的密码。

程序代码如下:

string oldid

string oldp

string newp1

string newp2

oldid=trim(sle_1.text)

oldp=trim(sle_2.text)

newp1=trim(sle_3.text)

newp2=trim(sle_4.text)

if len(oldp)=0 or isnull(oldp) then

oldp=space(10)

end if

if len(newp1)=0 or isnull(newp1) then

newp1=space(10)

end if

if len(newp2)=0 or isnull(newp2) then

newp2=space(10)

end if

select "operator"."password"

into :oldp

from "operator"

where "operator"."password"=:oldp;

if sqlca.sqlcode0 then

messagebox("提示","原密码不正确!")

sle_2.text=""

sle_2.setfocus()

return

end if

if newp1newp2 then

messagebox("提示","两次新密码输入不同!")

sle_4.text=""

sle_4.setfocus()

return

end if

Update "operator"

set "password"=:newp1

where "operator"."operator_id"=:oldid;

if sqlca.sqlcode0 then

rollback;

messagebox("提示","密码更正错误! 请重设!")

return

end if

gs_password=newp1

commit;

messagebox("提示","密码修改成功!")

七、本操作可以看仓库里的商品并可对其进行插入和删除

八、从仓库查询所需要的商品

4 系统评价

系统的功能基本上已经实现,但是还是不够完善。但是在使用的时候还是能给用户带来一定的方便的。仓库的进货和出货在本系统中能直观的以表格形式反映出来,便于操作员的使用和决策者的管理。

4.1 系统特色

本系统要求用户进行验证之后才能进入相应的界面。有利于保护数据库的安全,不被非法登陆使用。对于仓库内货物的进出管理要求严格,即进出货时必须填写相应的进出货单据。便于企业管理查看账目,保障了企业的稳定运行。通过本系统可以方便地实现仓库管理中的货物登记、出库入库等操作,使仓库管理井井有条。在查看数据库时可以方便的删除数据库中冗余的信息和添加新的信息。

4.2 系统不足及改进

这个系统基本上实现了一些简单的对系统所涉及表的更新、增加和删除的功能。也实现对用户登陆的安全上有了一定的限制,只有在正确输入ID和密码的时候才能进入系统。远没有达到大型公司的仓储物资管理的要求,所创建的数据库框架比较简单,各表之间的联系也过于简单,没有添加外键相互约束,用POWER BUILDER做出来的系统过于简单、单调,需要进一步深入的调整优化,将各表之间的关系紧密联系起来,相互制约,保证数据库中数据的添加、删除、更新,安全有序。操作窗口还需要进一步的进行美化,使用户在使用中更赏心悦目。

5 课程设计心得

这次课程设计的主要目的是掌握数据库应用系统分析设计的基本方法,基本掌握PowerBuilder,进一步提高分析解决问题的综合能力。通过这次课程设计,我基本掌握了以上要求。但只有两周的课程设计时间,时间比较仓促,所以开发的系统不是很完善,有一些功能未实现,但是仓库管理的基本功能均已实现。以前对数据库的很多知识认识都不深刻,做过这次课程设计之后,我对数据库的知识有了一个比较系统的了解;比如:对表内一些字段的约束,关系等的运用已经比较熟练。这个课程设计使我巩固了数据库的知识。

对于PowerBuilder也有了一定的了解,由于用的不多,所以运用的不是很熟练。刚开始的时候,对于PowerBuilder的语法,用法等一系列知识都不熟悉。当我基本完成此系统开发的时候,我发现其实也没有那么难,在未做之前我还害怕做不出来。经过对这个系统的开发,在开发过程中遇到但也解决了很多问题,所以说我们不能惧怕有困难而不去接触认识它,我们要知难而上,只有这样我们才能成长,才能有所发展。

这认为最难的一部分是用户查看数据库时通过插入删除按钮对数据库的更改,因为我们在文本框中输入的数字是被默认为字符型的,我在其中使用了integer(string)这个函数把字符型的进行了转换,但是在使用的过程中并不能像我所想像的那样有用。因为时间有限,所以这个问题还没有完全的解决。

通过这次数据库课程设计加深我对数据库基础理论和基本知识的理解,掌握数据库应用系统设计开发的基本方法,达到进一步使我综合运用所学知识和增强实际动手能力的目的。

我会继续学习数据库的知识,学习PowerBuilder的知识,只有通过不断的学习充实自己,才能让自己有所得。只有了知识的积淀,才能为自己的发展铺平道路!

可以参考一下啊,最终还是要自己做的吧。。仅供参考。

求助,现在要做个数据库,用access 2007做的一个课程管理系统,给个思路

首先要想清楚有什么功能,有什么流程,然后设计表格,确定表间关系.

然后做查询,

然后设计窗体,

大部分功能可以通过窗体的VBA代码实现.

最后是报表.

求数据库课程设计,医药管理系统代码

你可以去百度搜索,有很多相关的,

一般很少有人会给你源代码的,10分别人肯定不会给你了

(责任编辑:IT教学网)

更多

推荐Painter教程文章