自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+

Yatere的天平秤

人生就好像一杆天平,虽明知没有绝对的平衡,但我们也在不断尝试,因为我们相信奇迹也许会发生。

  • 博客(394)
  • 资源 (22)
  • 收藏
  • 关注

原创 How to set the current user on the model instance in the admin:

# app/models.pyfrom django.db import modelsfrom django.contrib.auth.models import Userclass Post(models.Model): user = models.ForeignKey(User) content = models.TextField()class Comment(

2012-12-03 10:23:59 967

原创 django 分页

数据多了在一页全部显示不仅不美观,也给服务器带来很大压力。django提供了分页的工具,那就是paginator类,下面来看看该怎么用:首先要导入该类:from django.core.paginator import Paginator认识Paginator类class Paginator(object_list, per_page,orphans=0,allow

2012-12-01 01:46:04 995

转载 总结Django中的用户权限模块

http://www.cnblogs.com/lddhbu/archive/2012/06/26/2564072.html该模块由用户(Users)权限(Permissions)组(Groups)消息(Messages)这些从字面上也都很好的理解,但是我对消息(Messages)还不是很理解…………1、安装1)将'django.contrib.a

2012-11-29 21:15:50 953

原创 常见的modeladmin,model

from django.contrib import adminfrom dbs.models import data,textclass txtindat(admin.StackedInline): model=text class admdat(admin.ModelAdmin): list_display=['username','email','passwo

2012-11-28 17:32:53 1121

原创 django 常用部分代码

对于开发模式:相对目录:os.path.join( os.path.dirname( __file__ ), 'templates' ).replace( '\\', '/' )静态文件影射(r'^(?P.*)$','django.views.static.serve',{'document_root':STATIC_ROOT}),直接模板映射,其他类似

2012-11-21 23:46:56 1003

转载 django 模板内建的模板过滤器

免得查找,直接copy一个addAdds the argument to the value.For example:{{ value|add:"2" }}If value is 4, then the output will be 6.This filter will first try to coerce both values to inte

2012-11-18 17:06:52 1294

原创 mysql 数据库转 存mdb py脚本

import MySQLdbimport win32com.clientimport os, sysos.chdir(sys.path[0])con = win32com.client.Dispatch(r'ADODB.Connection')DSN = 'PROVIDER=Microsoft.Jet.OLEDB.4.0;DATA SOURCE=yk.mdb;'sql_statem

2012-11-14 17:10:39 1070

转载 Django 开始支持py3

Django 1.5 alpha 1 releasedAs part of the Django 1.5 release process, today we've released Django 1.5 alpha 1, a preview/testing package that gives a little taste of some of the new stuff coming i

2012-10-28 21:55:03 731

原创 python 序列组合

import itertools as itst='0123456789abcdefghijklmnopqrstuvwxyz'#可以用string模块for i in range(4,9):#4到8位长度. for l in it.combinations_with_replacement(st,i): t='' for k in l:

2012-10-21 19:57:38 981 1

转载 sqlmap 使用,收藏备用

选取网站:http://www.XXXX.org/item.php?id=1,在sqlmap中输入命令:sqlmap -u http://www.XXXXX.org/item.php?id=1 --dbs 其中-u 是使用的url,--dbs是列数据库。若是能进行注入的话,该数据库就能列出来。结果如下:这样可以存在的数据库名称。发现数据库后需要获取数据库中的表信息。命令:sqlma

2012-10-16 22:14:47 1080

原创 go lang 读写文件操作

参考备份写程序离不了文件操作,这里总结下go语言文件操作。一、建立与打开建立文件函数:func Create(name string) (file *File, err Error)func NewFile(fd int, name string) *File具体见官网:http://golang.org/pkg/os/#Crea

2012-09-27 16:07:46 3088

转载 使用Golang 搭建http web服务器

转自:http://www.cnblogs.com/yjf512/archive/2012/09/03/2668384.htmlGolang在搭建web服务器方面的能力是毋庸置疑的。官方已经有提供net/http包为搭建http服务器做准备。使用这个包能很简单地对web的路由,静态文件,模版,cookie等数据进行设置。至于这个包是否好用,这个就见仁见智了。你可以从net包开始

2012-09-26 09:50:46 2321

原创 提供自学go的资料

好多资料,首先就是:https://github.com/astaxie/build-web-application-with-golanghttps://github.com/wonderfo/wonderfogo/wiki形星的电子书也不错。还有google的go论坛和官网了。一些民间个人博客,群,论坛等。PS:某人需

2012-09-26 09:48:06 1114

转载 go语言的php cgi执行程序

/* PHP FactCGI Remote Code Execute Exploit* Date: 2012-09-15* Author: wofeiwo@80sec.com* Affected: All PHP-FPM exposed outsie, but "system" cmd only affects >=5.3.3* !!Note: Only for research purp

2012-09-23 20:23:41 3217

转载 IIS 6.0/7.0/7.5、Nginx、Apache 等 Web Service 解析漏洞总结

[+]IIS 6.0目录解析:/xx.asp/xx.jpg  xx.jpg可替换为任意文本文件(e.g. xx.txt),文本内容为后门代码IIS6.0 会将 xx.jpg 解析为 asp 文件。后缀解析:/xx.asp;.jpg     /xx.asp:.jpg(此处需抓包修改文件名)IIS6.0 都会把此类后缀文件成功解析为 asp 文件。(站长评论:IIS6.0解析漏洞的

2012-09-12 23:28:00 2001

转载 Go语言_eclipse环境搭建(继上篇)

1 下载eclipse 2 下载goeclipsehttp://code.google.com/p/goclipse/wiki/InstallationInstructions 3 下载GoCodehttps://github.com/nsf/gocode下载源码到Gopath路径下Go build可以到父目录上生成了

2012-08-23 18:39:55 2457

原创 Go语言_HTTP包

在Golang中写一个http web服务器大致是有两种方法:1 使用net包的net.Listen来对端口进行监听2 使用net/http包 http客户端这里是讨论如何使用net/http包创建一个web服务器net/http请求提供了HTTP客户端和服务端的具体实现import ( "fmt" "net/http"

2012-08-23 18:26:33 1921

转载 Golang/Go语言/Go IDE/Go windows环境搭建/Go自动提示编译器/GoSublime

Go是Google开发的一种编译型,并发型,并具有垃圾回收功能的编程语言。  罗伯特·格瑞史莫(Robert Griesemer),罗勃·派克(Rob Pike)及肯·汤普逊于2007年9月开始设计Go语言,Go语言是基于Inferno操作系统所开发的。Go语言于2009年11月正式宣布推出,并在Linux及Mac OS X平台上进行了实现. GO语言吉祥物,很可爱吧。

2012-08-18 10:30:27 2011

转载 python 匿名ftp扫描

freebuf上面的一个py代码。仅供思想参考#!/usr/bin/env python """FtpScan.py - Scans for FTP servers allowing Anonymous Login Written by Sotd - twitter.com/#!/Sotd_ Performance update by q8r9e4"

2012-08-09 21:11:43 1337

转载 SSH隧道与端口转发及内网穿透

SSH隧道与端口转发及内网穿透本文的受众如果你遇到了以下问题,那么你应该阅读这篇文章我听说过这种技术,我对它很感兴趣我想在家里访问我在公司的机器(写程序,查数据,下电影)。公司为了防止我们用XX软件封锁了它的端口或者服务器地址。公司不让我们上XX网站,限制了网址甚至IP。公司不让我们看关于XX的信息,甚至花血本买了XX设备,能够对内容进行过滤。一看XX内

2012-07-29 12:45:10 1984

转载 preg_replace 代码执行原理

以前dz2漏洞,结果今天看到这个函数,就把老文转过来,方便自己备份preg_replace函数原型:mixed preg_replace ( mixed pattern, mixed replacement, mixed subject [, int limit])特别说明:/e 修正符使 preg_replace() 将 replace

2012-07-19 23:08:23 3324 1

原创 利用小马下载全站程序,(php inc格式文件包括目录结构)的py代码

如果有小马了,就可以用本程序下载全站程序。代码如下:import urllib.request as urimport urllib.parse as upimport threading,queue,os,sysque=queue.Queue()os.chdir(sys.path[0])key='pass' #小马的密码url=r'http://localhost/te

2012-07-16 10:48:34 2235

原创 py3 写的基于GUI 的 旁注 wwwscan集成扫描工具

软件作用:1.自动旁注指定IP段,收集旁注信息,并自动保存为文本文件方便以后查看。2.自动多线程针对第一步骤的网站结果调用wwwscan进行扫描。(可以自己定义多少线程)全部都是自动化完成。程序界面如下:代码如下:from tkinter import *import httplib2,os,queue,threading,sys,socket,time,

2012-07-11 00:53:00 2439

原创 基于tornado的web探测系统(自带旁注、端口扫描、whois、sql注入监测)

http.py import tornado.ioloop,osimport tornado.webimport unit,socketuser='yk'passwd='123'class MainHandler(tornado.web.RequestHandler): def get(self): self.write(''' 目标:

2012-07-06 21:14:33 2445

原创 用于演示mssql 注入的漏洞代码

需要演示,所以临时写了一个,主要是介绍原理:<%dim conn dim connstr Set conn = Server.CreateObject("ADODB.Connection") connstr="driver={SQL Server};server=192.168.1.128;UID=sa;PWD=123;database=123" conn.Open co

2012-07-05 23:38:05 1197 1

原创 php整站打包程序

asd PHP整站打包程序-By DoDo <?php ini_set('memory_limit', '2048M'); echo "选择要压缩的文件或目录:"; $fdir = opendir('./'); while($file=readdir($fdir)) { if($file=='.'|| $file=='..')

2012-07-03 16:23:30 2719 1

原创 百合网外挂

应某位2b人士要求,代码如下(未优化,短期完成),麻烦闭住带屎嘴巴。#coding=GB18030import urllib.request as urimport urllib.parse as upimport time,jsoncookie=ur.HTTPCookieProcessor()oper=ur.build_opener(cookie)def now():

2012-07-02 09:22:39 2599

原创 python 内存映射文件

可以直接吧内存的对象作为 类 list file 读写赋值啦。好方便!eg:import mmap# write a simple example filewith open("hello.txt", "wb") as f: f.write(b"Hello Python!\n")with open("hello.txt", "r+b") as f: # m

2012-06-23 10:07:47 2795

转载 python 3 操作mssql

没有标准的库,只好曲线救国。本文介绍使用python,adodbapi操作数据库:adodbapi 库python 可以操作mssqlserver的类库有几个,支持python3.x的目前没几个靠谱的详细过程:首先添加引用:import adodbapiadodbapi.adod

2012-06-20 23:51:22 3422 2

转载 Drupal核心路径泄露漏洞

版本:Drupal Drupal 7.xhttp://localhost/?q[]=x-------------------------------------Hotfix:Search for:$path = trim($path, '/');And add the following line above:if(is_

2012-06-17 23:35:05 1433

转载 MyBB MyBB 1.6.8 'member.php' SQL注入漏洞

http://www.example.com/forums/member.php?action=profile&uid=[Sqli]http://www.example.com/Patch/member.php?action=warning_level&customfield=[Sql]

2012-06-17 23:34:09 18121

转载 CVE-2012-2122: MySQL身份认证漏洞

http://seclists.org/oss-sec/2012/q2/493我今天早上打开电脑,在seclists中看到一个很惊人的thread:http://seclists.org/oss-sec/2012/q2/493MySQL爆出了一个很大的安全漏洞,几乎影响5.1至5.5的所有版本。出问题的模块是登录时密码校验的部分(password.c),在知道用户名的情况下(如

2012-06-11 21:29:01 1784

原创 使用php发起多线程cc请求

<?phpset_time_limit(0);ignore_user_abort(FALSE);$exec_time = $_POST['time'];$t='http://localhost/index.asp';$urls=array_fill(0,512,$t);$time = time();$max_time = $time+$exec_time;while (1

2012-06-07 00:59:15 951

原创 http代理验证程序

配合上一篇文章的攻击脚本import socket,threading,os,sys,queue,resocket.setdefaulttimeout(5)path=sys.path[0]if os.path.isfile(path): path=os.path.split(path)[0] domain='www.baidu.com'que=queue.

2012-05-31 16:55:05 998

转载 PEP 333 (不是3333)的翻译

<!--.borderless, table.borderless td, table.borderless th {border:0}table.borderless td, table.borderless th {padding:0 0.5em 0 0!important}.first {margin-top:0!important}.last, .with-su

2012-05-29 20:58:02 4016 2

原创 针对网页流量的Dos攻击脚本(使用代理服务器)

某目标网站,为虚拟主机,如果ISP限制月流量为20G,那么我们可以在短暂1-2天内消耗完其流量。(取决于你的机器)方法原理如下:1.找到目标网站大文件(页面)地址2.多线程访问(下载)该地址(注意:由于完全是出于模拟真实用户,所以不会被防火墙屏蔽掉)(以下以hao123为例子而已)一: 其中以上思路中的第一点 可以通过google浏览器的审计功能实现

2012-05-29 12:18:38 1995

原创 直接下载豆瓣fm的全部歌曲py脚本。(json操作)

没有多线程,临时听到后觉得好听就随手写了一个。用到了json模块。import urllib.request as urimport json,os,sysos.chdir(sys.path[0])t=r'http://douban.fm/j/mine/playlist?type=n&channel='for i in range(24): url=t+str(i)

2012-05-25 12:12:18 2334 3

转载 Editplus SVN 设置

SVN在团队开发的时候很强大。VS有VisualSVN插件,但是我不喜欢用VS。vim电脑上也有,虽然很多人说vim也很强大,不过我目前还是习惯editplus。也许以后会去适应vim吧。1、首先这里有一篇介绍,edtiplus使用SlikSVN来实现update、commit。当然前提也是要安装TortoiseSVN的。2、发现了一个更好的介绍,是deitplus wiki里面的

2012-05-17 09:55:58 1248

转载 netstat 源码(占个地方)

#include "Winsock2.h"#include "Iphlpapi.h"#include #include #include #pragma comment(lib, "Iphlpapi.lib")#pragma comment(lib, "ws2_32.lib")static char TcpState[][32] = { "???",

2012-05-12 21:36:26 1899 3

原创 window 匿名管通道编程

放个代码片段方便我以后做事SECURITY_ATTRIBUTES sa;HANDLE hRead,hWrite; sa.nLength = sizeof(SECURITY_ATTRIBUTES); sa.lpSecurityDescriptor = NULL; //使用系统默认的安全描述符 sa.bInheritHandle = TRUE; //创建的进程继承句

2012-05-12 17:37:59 900

Crypto.pptx

Crypto.pptx

2021-09-20

python flask教程,html格式

python flask web开发框架教程,html格式,寻迹渐进。

2018-11-01

lcx修改版,端口转发工具,内网端口转外网

内网打洞工具,原理同lcx,但是更强大,方便。

2015-04-28

wrodpress dos tools

利用 xmlrpc.php 的漏洞对,wordpress drupal 等采用xmlrpc 服务的拒绝服务工具。

2014-08-12

hydra 7.2 win32

H Y D R A (c) 2001-2012 by van Hauser / THC http://www.thc.org co-maintained by David (dot) Maciejak @ gmail (dot) com BFG code by Jan Dlabal Licensed under GPLv3 (see LICENSE file) INTRODUCTION ------------ Number one of the biggest security holes are passwords, as every password security study shows. This tool is a proof of concept code, to give researchers and security consultants the possiblity to show how easy it would be to gain unauthorized access from remote to a system. THIS TOOL IS FOR LEGAL PURPOSES ONLY! There are already several login hacker tools available, however none does either support more than one protocol to attack or support parallized connects. It was tested to compile cleanly on Linux, Windows/Cygwin, Solaris, FreeBSD and OSX. Currently this tool supports: AFP, Cisco AAA, Cisco auth, Cisco enable, CVS, Firebird, FTP, HTTP-FORM-GET, HTTP-FORM-POST, HTTP-GET, HTTP-HEAD, HTTP-PROXY, HTTPS-FORM-GET, HTTPS-FORM-POST, HTTPS-GET, HTTPS-HEAD, HTTP-Proxy, ICQ, IMAP, IRC, LDAP, MS-SQL, MYSQL, NCP, NNTP, Oracle Listener, Oracle SID, Oracle, PC-Anywhere, PCNFS, POP3, POSTGRES, RDP, Rexec, Rlogin, Rsh, SAP/R3, SIP, SMB, SMTP, SMTP Enum, SNMP, SOCKS5, SSH (v1 and v2), Subversion, Teamspeak (TS2), Telnet, VMware-Auth, VNC and XMPP. However the module engine for new services is very easy so it won't take a long time until even more services are supported. Your help in writing, enhancing or fixing modules is highly appreciated!! :-) HOW TO COMPILE -------------- For hydra, just type: ./configure make make install If you need ssh module support, you have to setup libssh on your system, get it from http://www.libssh.org, for ssh v1 support you also need to add "-DWITH_SSH1=On" option in the cmake command line. If you use Ubuntu, this will install supplementary libraries needed for a few optional modules: apt-get install

2012-04-09

用Python做科学计算

软件包的安装和介绍 安装软件包 函数库介绍 NumPy-快速处理数据 ndarray对象 ufunc运算 矩阵运算 文件存取 SciPy-数值计算库 最小二乘拟合 函数最小值 非线性方程组求解 B-Spline样条曲线 数值积分 解常微分方程组 滤波器设计 用Weave嵌入C语言 SymPy-符号运算好帮手 封面上的经典公式 球体体积 matplotlib-绘制精美的图表 快速绘图 绘制多轴图 配置文件 Artist对象 Traits-为Python添加类型定义 背景 Traits是什么 动态添加Trait属性 Property属性 Trait属性监听 TraitsUI-轻松制作用户界面 缺省界面 自定义界面 配置视图 Chaco-交互式图表 面向脚本绘图 面向应用绘图 TVTK-三维可视化数据 TVTK使用简介 TVTK的改进 Mayavi-更方便的可视化 用mlab快速绘图 Mayavi应用程序 将Mayavi嵌入到界面中 Visual-制作3D演示动画 场景、物体和照相机 简单动画 盒子中反弹的球 OpenCV-图像处理和计算机视觉 读写图像和视频文件

2012-04-04

pyloris-3.2-win32

Using HTTPLoris is simple. In its most basic form, HTTPLoris merely needs a copy of Python 2.6. On a Linux machine, one must simply invoke the script in a terminal, stating a site to test: motoma@rocksalt:/home/motoma$ python pyloris-3.0.py motomastyle.com On Mac OS X, one invokes PyLoris the same way. Using the Terminal Application: hotdog:/Users/Motoma/ motoma$ python pyloris-3.0.py motomastyle.com Using HTTPLoris in Windows is a little different. One will need to know the location of the Python installation, and be in the proper directory. Load up a command prompt: C:\Users\Motoma\Desktop\pyloris-3.0>C:\Python26\python.exe pyloris-3.0.py motomastyle.com Advanced Options Invoking HTTPLoris by using the commands above start a limited to 500 connections across 50 threads, each sending at 1 byte/second and waiting until the connection is forced shut by the server. While this behavior will bog down an Apache server with the default settings, it is not a very thorough test. The following are some additionall options that will allow one to customize the way HTTPLoris works: -a, --attacklimit The --attacklimit flag restricts the number of total connections (current + completed) during a single session. Set this to zero to specify no limit. -c, --connectionlimit Adjusting the --connectionlimit flag can drastically change how well HTTPLoris performs. The --connectionlimit flag directly controls the number of concurrent connections held during the session. In a base Apache environment, when this number is above the MaxClients setting, the server is unresponsive. -t, --threadlimit This is the number of attacker threads run during the session. -b, --connectionspeed This is the connection speed for each individual connection in bytes/second. Comparing this with the lenght of the request, and you should have an accurate guess of how long each connection should linger. -f, --finish Specifying the --finish flag will cause HTTPLoris to finish and close connections upon

2012-03-17

灰帽Python-黑客和逆向工程的Python编程(中文)

灰帽Python-黑客和逆向工程的Python编程(中文)

2012-02-25

类似IE的VC编写浏览器

利用已有的HTTP控制、HTML解释器和HTML执行器,通过MFC提供的CHtmlView类实现的一个Windows下的多功能的浏览器,其功能包括:WEB站点浏览、本地和网络的文件系统的浏览、历史记录的维护、IE收藏夹功能和设置桌面快捷方式功能等。

2012-01-28

Using_XSS_to_bypass_CSRF_protection

Hello, in this tutorial I will teach you how to use XSS to bypass CSRF protection. If you are familiar to XSS and CSRF terms you can skip the first two chapters, but I recommend you read them. Warning! This tutorial was written for educational purposes only ,and I take no responsibility for your acts.

2012-01-28

C语言难点及分析.

这篇文章主要是介绍一些在复习C语言的过程中笔者个人认为比较重点的地方,较好的掌握这些重点会使对C的运用更加得心应手。此外会包括一些细节、易错的地方。涉及的主要内容包括:变量的作用域和存储类别、函数、数组、字符串、指针、文件、链表等。一些最基本的概念在此就不多作解释了,仅希望能有只言片语给同是C语言初学者的学习和上机过程提供一点点的帮助。

2012-01-28

向其他进程注入代码的三种方法

向其他进程注入代码的三种方法 ●Windows 钩子(Hooks) ●CreateRemoteThread 和LoadLibrary 技术 ○进程间通讯 ●CreateRemoteThread 和 WriteProcessmemory 技术 ○如何使用该技术子类(SubClass)其他进程中的控件 ○什么情况下适合使用该技术

2012-01-28

windows+API+一日一练

熟悉常见windows的各类api操作,包括内存、磁盘等

2012-01-28

jQuery1.2 API 中文版

绝对最棒,文档条理性非常不错, 简明扼要。 包括核心函数,选择器 属性、筛选、文档处理 css 事件 效果 ajax等

2011-08-21

网站安全漏洞的产生分析、处理总结

一:网站程序存在的漏洞 1. 注入漏洞 2. 上传文件格式验证不完善 3. 参数可写入文件——构造一句话 4. mdb数据库改用ASP\ASA等名字作为数据库扩展名(添加防下载代码) 5. 后台显示数据库路径 6. 数据库可备份修改扩展 7. 文件管理部分传递参数过滤问题及外部提交 8. XSS漏洞骗取cookies得到后台权限 9. 任意文件下载漏洞 10. 远程包含漏洞 11. 使用未加密的cookies进行用户权限等级及权限验证 12. session被构造欺骗

2011-04-21

一个月挑战C++.rar

快速入门,经典教材,一个月内速成C++高手,短期。

2010-11-08

VC学习大纲 VC学习讲义

第一课: Windows程序运行原理及程序编写流程,窗口产生过程,句柄原理,消息队列,回调函数,窗口关闭与应用程序退出的工作关系,使用VC++的若干小技巧,stdcall与cdecl调用规范的比较,初学者常犯错误及注意事项。我们通常不必要知晓每一个函数和消息。但另一方面,也不得不记住其中的一部分,否则很难将VC++运用自如。到底该记住哪些,这在我们的课程中都会涉及到。 第二课: C++经典语法与应用,类的编写与应用,构造与析构函数,函数的重载,类的继承,函数覆盖,基类与派生类的构造函数、析构函数先后调用顺序,如何在派生类构造函数中向基类的构造函数传递参数,this成员变量,类型转换的内幕,虚拟函数与奇妙多态性。VC工程的编译原理与过程,将工程中不同的类拆分到不同的原文件中,每一个类由一个.h和.cpp文件共同完成,然后解决头文件重复定义问题,培养了学员良好的编程习惯,也为以后分析MFC Appwizard生成的工程奠定了良好基础。 第三课: 讲述MFC AppWizard的原理与MFC程序框架的剖析。AppWizard是一个原代码生成工具,是计算机辅助程序设计软件,Winmain在MFC程序中是如何从源程序中被隐藏的,theApp全局变量是如何被分配的,MFC框架中的几个类的作用与相互关系,MFC框架窗口是如何产生和销毁的,对窗口类的PreCreateWidow和OnCreate两个函数的着重分析,Windows窗口与C++中的CWnd类的关系。 第四课: 讲述如何运用ClassWizard及对MFC消息响应函数机制的分析,理解发送给窗口的消息是如何被MFC框架通过窗口句柄映射表和消息映射表来用窗口类的函数进行响应的。掌握设备描述表及其封装类CDC的使用,CDC是如何与具体的设备发生关联的,融合具体的画图程序进行分析。如何设置封闭图形的填充刷子(位图画刷与透明画刷的使用)。 第五课: 掌握CDC的文字处理程序的编写,如何产生自定义字体和自定义插入符,熟悉对CString类的使用。通过对kala ok程序的编写,讲解定时器的使用和DrawText函数的巧妙运用。讲解如何使用CDC的裁减功能。 第六课: 菜单的工作原理及编写应用,菜单命令消息在MFC框架程序的几个类中的传递顺序和处理过程。标记菜单的实现原理、图形菜单的实现及常犯错误的分析,GetSystemMetrics的应用,快捷弹出菜单的实现方式及其命令响应函数有效范围(与弹出菜单时所指定的父窗口有密切的关系,最底层的子窗口具有最优先的处理机会)。 第七课.: 动态菜单的编写,如何让程序在运行时产生新的菜单项及如何手工为这些新产生的菜单命令安排处理函数,如何在顶层窗口中截获对菜单命令的处理,更进一步掌握CString类的应用。 第八课.: 对话框用户界面程序的编写,如何向对话框控件联接数据成员及其实现机理,如何向对话框控关联控件类,如何利用对话框类的成员函数向控件发送消息和获取对话框控件的类指针,如何直接利用对话框控件类操纵对话框控件(发送消息和直接调用成员函数)。如何在程序运行时产生和销毁控件。对话框控件的几种操作方式的优劣比较分析。 第九课: 如何让对话框上的文本框在程序启动后立即获得焦点,如何利用SetWindowLong改变窗口的回调函数,通过改变文本框的默认回车处理方式进行演示。实现多个输入文本框间通过回车逐一向下传递焦点的另一种巧妙方法(用缺省按钮来处理)。利用SetWindowLong和定时器轮回改变窗口的图标。如何实现对话框的部分收缩和展开。如何在主对话框程序启动时立即隐藏对话框的巧妙实现方式与精妙思想(不能直接在OnInitDialog处理。包括自定义消息的实现) 第十课: 如何制作属性页对话框和向导对话框,融合讲解组合框(如何调整组合框的大小)、列表框、单选按钮、复选按钮 等常用对话框控件的多种使用方法。如何限制用户在不满足设定的条件时切换到其他属性页和向导页。 第十一课: 如何修改MFC AppWizard向导生成的框架程序的外观,包括修改标题栏的多种方式及原理,修改图标、光标、背景的两种方法。如何给应用程序增加工具栏和删除工具栏按钮。定制状态栏,在CView中获取状态栏对象的几种方式,在状态栏中添加时钟显示(掌握CTime类和静态成员变量和函数的用法),鼠标坐标显示,进度条(主窗口产生后立即产生进度条的巧妙思想,不能在OnCreate函数中直接处理,要用到自定义消息的方法)。如何为窗口添加背景位图。 第十二课: 如何使用自定义画笔(颜色,线宽,线形),画刷(形状,颜色)。如何为程序中添加选项菜单和选项设置对话框,如何使用标准颜色对话框,窗口重绘原理,在选项对话框中实现预览功能。实现选项对话框和窗口类中的数据交换。 第十三课: 如何让CDC上输出的文字、图形具有保持功能,元文件设备描述表的使用,CpaintDC与CClientDC的区别与应用,OnPaint与Ondraw在CView中的关系及实现内幕,集合类CObArray的使用,滚动窗口的实现,设备坐标与逻辑坐标的转换。 第十四课: 文件读写,CFileDialog,CFile,fstream,CArchive类的使用与比较。在应用中讲解const char *与char * const的区别,字符串的使用原理,如何使用CString的内存缓冲区。注册表与win.ini文件的读写方式及相关知识点。 第十五课: 如何利用CDocument类的串行化存储功能及MFC框架程序提供的文件打开与保存功能的实现原理。如何实现类对串行化的支持,CObArray的串行化实现内幕。MFC框架程序的几个主要类之间如何获得相互的指针引用。 第十六课: 网络程序的编写,Socket是连接应用程序与网络驱动程序的桥梁,Socket在应用程序中创建,通过bind与驱动程序建立关系。此后,应用程序送给Socket的数据,由Socket交给驱动程序向网络上发送出去。计算机从网络上收到与该Socket绑定的IP+Port相关的数据后,由驱动程序交给Socket,应用程序便可从该Socket中提取接收到的数据。网络应用程序就是这样通过socket进行数据的发送与接收的。UDP与TCP的工作原理与编写过程,包含如何在程序中连接库文件,telnet工具软件在编写网络程序中的用途 第十七课: 多线程程序的编写,如何通过互斥来保证多线程的安全。如何利用命名互斥保证只有一份程序实例被运行,结合多线程,网络编程,自定义消息,数据类型转换,如何改变文本框对回车的默认处理方式等技术编写网络聊天程序。 第十八课: 动态连接库程序的编写,库函数的两种输出方式。调用程序对动态连接库的静态连接与动态连接方式,如何利用工具查看动态连接库里的函数,C/C++连接规范中的命名转变问题分析,如何获得动态连接库里的函数 的指针,如何用typedef声明指向函数的指针类型。如何调试动态连接库。 第十九课: ActiveX控件的应用与工作原理,ActiveX控件的编写,如何为控件安排属性,方法,事件,属性页,持久性存储。如何注册控件与取消控件注册。如何测试与调试控件。 第二十课: 综合答疑与一些高深主题的介绍,包括如何安装系统钩子函数,dll连接库里的全局变量数据共享问题分析,ADO数据库编程,如何将数据库记录显示在Clistview网格中。 以上内容为作者对课件的初步整理,还有很多课堂上要讲到,但在本大纲中还没有被撰稿的内容,以后将逐渐完善本大大纲。

2009-06-09

The Analysis Of Basic MFC Program Running Principle

分析MFC流程,框架,WIN32 api 之间关系的文章,对于MFC初学者强烈推荐!! 有PDF和doc2种格式

2008-12-29

Visual C++ MFC 简明教程

Visual C++ MFC 简明教程 ,共享出来,也许对于某些人有用!

2008-12-29

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除