自定义博客皮肤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)
  • 收藏
  • 关注

原创 Python 使用标准库原始socket 生成 pcap 文件

注意事项 :1.仅限linux/uninx 使用2.不需要任何第三方库,仅用标准库3.格式为公开格式,可以whireshark 直接打开代码如下:import time,structclass Pcap: def __init__(self, filename, link_type=1): self.pcap_file = open(filename, 'wb') self.pcap_file.write(struct.pack

2021-08-23 23:21:53 1163

原创 提供twitter和facebook爬虫服务

1、twitter 和facebook uid和username 互转注: facebook 有部分username无法获取2、twitter和facebook爬虫服务注:facebook:分为匿名和非匿名爬虫,非匿名:爬取数据类型最全和内容可以最多,但存在较大限制。匿名:可以爬取用户最近发布内容以及类似用户推荐和基本信息(邮箱地址等信息),存在一定限制。twitt...

2020-04-21 13:08:05 1638 7

原创 python 修饰符的理解和一个通用模版例子

例子是多个修饰符参数的例子def decorator_factory(enter_message, exit_message): # We're going to return this decorator def simple_decorator(f): def wrapper(*args, **kwds): print ent

2018-01-06 00:48:47 1457 3

转载 树莓派扩容SD系统卡

步骤1: 重新启动你的电脑,不要启动X windows步骤2: $ sudo df -h你应该会看到/ 挂载于rootfs(已使用97%左右)。步骤3: $ sudo fdisk /dev/mmcblk0命令:按P(印刷)你应该会看到三个分区,现在把分区2的信息写下来(/dev/mmcblk0p2)。命令:按d(删除分区2)命令:按p(印刷)现在应该会看到2个分区命令:按n(

2017-12-25 19:15:51 2871

转载 CTF线下防御战 — 让你的靶机变成“铜墙铁壁”

一. 前言随着CTF的普及,比赛的形式也有了越来越多的花样,对于线下赛来说,开始出现了安全加固或者防御战之类的环节,亦或者因为拿下靶机后不希望其他攻击者进入而进行“争夺”,无论什么形式,这些都需要我们对于服务器的防护工作有所了解。对于线下赛,笔者虽说没有什么很高超的攻防技巧,但也是有着一些自己的心得。本文总结了一些CTF线下赛中常用的服务器加固姿势,希望能对各位CTF朋友们有所帮助。环境针

2017-12-21 10:46:04 6730

原创 flask 后台程序执行方法

由于flask后台多线程、多进程都是假的,所以想异步操作必须多一些代码内容。解决方法主要是2种:一、使用Celery (http://www.celeryproject.org/),或者RQ (http://python-rq.org/).实现异步分布式后台操作。二、简单的使用python代码了:# -*- coding: utf8 -*-from fla

2017-12-21 10:37:17 12184

原创 Telegram实现判断目标手机号是否注册

以前已经谢好了批量工具自动获取用于信息,现在需要优化,预先判断是否注册,然后再爬取信息。以前代码涉及隐私和漏洞,不便发布,检测是否注册为公开client api,实现基于 python,不需要手机注册。代码如下:、# Telethon==0.15.5.7from telethon import TelegramClientimport re,timefrom

2017-12-18 09:35:55 13083 7

原创 TCP Packet Injection with Python

项目地址:https://github.com/OffensivePython/PinjectRaw Packet Injection tool比起scrpy 起来简单多了,当然功能不如他,但是自己写一些raw的程序经测试笔scrpy快很多。注:windows下不支持sock raw.例子: # IP Header ipobj = IP(src_host, dst_ho

2016-12-27 14:30:14 2049

转载 终极Web应用性能和压力测试工具Gor

什么是Gor项目地址:https://github.com/buger/gor官方描述Gor is a simple http traffic replication tool written in Go.Its main goal is to replay traffic from production servers to staging and dev env

2016-05-19 09:41:29 6095

原创 python 汉子转拼音库

今天写个小程序遇到了,做个备份吧1、安装   pip  install  zpinyin例子: >>> from xpinyin import Pinyin>>> p = Pinyin()>>> # default splitter is `-`>>> p.get_pinyin(u"上海")'shang-hai'>>> # show tone marks

2015-12-16 21:27:03 2602

原创 在家刷滴滴顺风车

每天上下班开车,为了节约油钱 过桥费等,都会使用顺风车查看是否有顺路的单。 现在写了一个程序,不需要拿着手机刷了,每天下班回家,或者上班在单位电脑开着即可,一旦有顺路的乘客,程序会自动发出声音报警。你需要做的只是这个时候再拿出手机,抢单即可。程序代码:#!/usr/bin/env python# -*- coding: gb18030 -*-import urllib2 as

2015-07-16 20:29:03 5482 10

原创 多个文本文件两两碰撞相同内容

# -*- coding: cp936 -*-import os,sys,glob,itertoolsos.chdir(sys.path[0])def getsame(a,b): la=[] lb=[] for i in open(a): la.append(i.strip()) for i in open(b): lb.ap

2015-07-10 20:58:28 2066

原创 内网打洞,类似于lcx 但是比他更加强大

经常有朋友用lcx的,但是由于很多原因可能都不好使,例如 :1.linux下能用lcx,有时只能拿msf出来。(golang的程序跨平台,甚至嵌入式linux都支持。)2.不免杀  (基本上目前golang 语言不会被当病毒)3.每次内网要从新连接其他主机时候,必须从进去从新敲打命令 ,操作过多任意被发现。(肉鸡只用操作一次,其他都交给主控端操作了)最近正好都碰上了,于是自

2015-04-28 18:06:00 4489 2

原创 dns服务器 、dns中间人篡改服务器

软件介绍: 本身为独立执行程序,跨平台,可以充当正常dns服务器。默认情况下,本程序只篡改MX(邮件交换记录)为特定主机。作用:本软件 与 本博客前文中的 smtp 中继监控服务器程序 结合来实施攻击,特别在内网中。其他:如果需要实现高级的基于特定域名的篡改,修改代码即可。package mainimport ( "fmt" "github.

2015-01-30 22:31:50 3239

转载 Python Raw编程

asd 使用原始raw编程需要系统支持,某些windows已经不支持class ip(object): def __init__(self, source, destination): self.version = 4 self.ihl = 5 # Internet Header Length self.tos = 0 # Type

2014-09-09 16:41:27 2549

转载 单个mdf sqlserver 文件的数据库恢复

一共3种方法,建议使用第一种。

2014-07-23 09:58:53 2137

原创 使用google map进行 gsm wcdma 基站定位获得及附近信息的代码

使用googlei# -*- coding: cp936 -*-#!/usr/bin/pythonfrom struct import pack, unpackfrom httplib import HTTPimport urllib2,json,fileinput,Queue,threading,time#组件信息proxy_handler = urllib2.ProxyHa

2014-04-23 11:05:19 3299

原创 python 抓http GET POST 客户端请求包(关键的是规则)

#!/usr/bin/env pythonfrom ctypes import *from winpcapy import *import stringimport time,os,sysimport platformos.chdir(sys.path[0])if platform.python_version()[0] == "3": raw_input=input

2014-02-06 17:01:04 3114

原创 家居监控,利用树莓派 每隔一分钟 拍摄相片上传 金山快盘

为了监控家里情况,这里使用了金山快盘作为存储,每隔一分钟上传拍摄相片。因为条件限制,树莓派不支持模拟信号处理,所以无法使用模拟信号传感器,后续会添加其他数字传感器包括外联arduino控制器,根据各种条件再来智能化拍摄。import urllib2,time,sys,osfrom urllib import urlencodefrom poster.encode import

2013-12-11 10:04:40 4151

原创 arduino 智能小车(蔽障、蜂鸣提醒、警示led灯,带串口输出)

#define Buzzer 2#define InfraredSensorPin 4#define LedDisp 13void setup(){ pinMode(Buzzer,OUTPUT); Serial.begin(9600); Serial.println("Start!"); pinMode(InfraredSensorPin,INPUT); pinMode(LedDisp,O

2013-12-02 19:24:27 5502 1

原创 python 修饰器

不常用,不过这几天用上了。顺便做个exp,跟闭包差不多def y(func): print 'this is aaa',type(func),func def myfun(arg): print 'this is bbb',type(arg),arg arg=arg+'213' return func(arg)

2013-05-25 16:40:54 2808 1

原创 wuyun 直接可以看的文章

for someone:不需要邀请码直接可以看的文章,截止今日,地址见下:http://zone.wooyun.org/content/29http://zone.wooyun.org/content/38http://zone.wooyun.org/content/44http://zone.wooyun.org/content/48http://zone.wooyun.

2013-05-17 00:13:44 3699

转载 py socket5 代理

python socket5 代理#!/usr/bin/python # Filename s5.py # Python Dynamic Socks5 Proxy # Usage: python s5.py 1080 # Background Run: nohup python s5.py 1080 & import socket, sys, select, SocketServe

2013-05-14 23:20:49 3006

原创 tcpdump Wireshark ,抓报分析脚本

import dpkt,os,sysos.chdir(sys.path[0])f = open('12.cap','rb')pcap = dpkt.pcap.Reader(f)for ts, buf in pcap: eth = dpkt.ethernet.Ethernet(buf) ip = eth.data tcp = ip.data try:

2013-05-13 15:42:20 2522

原创 踩点信息生成工具

# -*- coding: gb18030 -*-from subprocess import *import socket,httplib2import sys,os,socket,threadingfrom bs34 import BeautifulSoup34import json,urllib2,urllibfrom urlparse import urlparse as u

2013-04-30 00:42:19 2237

转载 python http proxy

# -*- coding: utf8 -*-import socket, thread, select__version__ = '0.1.0 Draft 1'BUFLEN = 8192VERSION = 'Python Proxy/'+__version__HTTPVER = 'HTTP/1.1'class ConnectionHandler: def __init__

2013-04-29 23:59:55 3167

原创 golang random string and int

package mainimport ( "fmt" "math/rand" "time" "bytes")func main() { fmt.Println(randomString(10) )}func randomString (l int ) string { var result bytes.Buffe

2013-04-20 15:45:52 4329

原创 python dns协议重写

可以指定dns查询,脱离本地dns设置。import socket,os,redef dns_remote_resolve(qname, dnsserver, timeout=None, blacklist=set(), max_retry=2, max_wait=2): for i in xrange(max_retry): index = os.u

2013-04-14 23:57:29 1961

原创 golang 读写文件内容(备份)

以下是读取文件内容package mainimport ( "bufio" "fmt" "io" "os" "strings")func main() { fh, ferr := os.Open("d:\\n.txt") if ferr != nil { fmt.Printf("An error occurred on

2013-04-14 23:21:41 4187

原创 常见查询接口

第一个接口,查询ip地址的地理信息接口:r'http://api.ipinfodb.com//v2/ip_query.php?key=5eb5b4de91741e2e4b98748989dc84f3236b55f6dd38aa689921884867536f36&ip={}&output=json&timezone=false'        获得子域名信息,google接口:se

2013-04-14 23:19:47 1666 2

转载 php webshell 加密代码

import reimport sysimport base64, codecsfrom random import random, randrange, choice, shuffle, randintfrom collections import *from inspect import getargspecdef random_string(charset = 'abcdefgh

2013-04-07 15:58:55 1761

原创 golang sort 排序

package mainimport ( "fmt" "sort")func main() { d := []int{5, 2, 6, 3, 1, 4} // unsorted sort.Sort(sort.IntSlice(d)) fmt.Println(d) // Output:[1 2 3 4 5 6] a := []flo

2013-04-06 23:25:06 6044

原创 golang rand 随机例子

package mainimport ( "fmt" "math/rand" "time")func main() { rand.Seed(time.Now().UnixNano()) for i := 0; i < 10; i++ { x := rand.Intn(100) fmt.Println(x) }}以上例子是打印10个100以内(0-99)的随机数

2013-04-06 22:57:41 35739 2

原创 任意数据类型切片 golang

package mainimport ( "fmt" . "strconv")type Element interface{}type List []Elementtype Person struct { name string age int}func (P Person) String() string { return "My name is " + P.n

2013-04-05 03:22:22 1663 1

原创 python 并发编程

python 并发除了直接基于编译内核的 Stackless   python还有比较突出的一些例如gevent,eventlet greenlet等,主要概念是协程。以下是用刷票(客户端)的例子,比多线程快n倍,不过还是不如Stackless:(ps:erlang并发还不如python 基于协程的Stackless)gevent效率要高于eventletimpor

2013-03-27 21:44:09 1702

原创 跨平台浏览器模拟控制测试

以前说过pam,最近因为要测试跨平台的,所以用上了这个。‘要说明的是,不支持IE,只支持:chrome , firefox , phantomjs , zopetestbrowser, remote webdriver顺便做个记录使用模块 splinter ,网站地址:http://splinter.cobrateam.info/也可以pip安装。演示代码:fr

2013-03-26 19:47:05 1166

原创 即时获得输出,方便集成

from subprocess import *import os,sysos.chdir(sys.path[0])p=Popen(['ping','-t','8.8.8.8'],shell=False,stdout=PIPE)data=p.stdout.readline()while data: print data.strip() data=p.stdout.rea

2013-02-25 18:26:35 884

原创 mail群发

#coding=utf8os.chdir(sys.path[0])#配置信息authInfo = {}authInfo['server'] = 'smtp.163.com'authInfo['user'] = '[email protected]'authInfo['password'] = '2JlP'fromAdd = '[email protected]'#toAdd = ['te

2013-01-05 15:17:54 1188

原创 批量QQ资料采集

#coding=utf8import httplib2,os,sys,timefrom bs4 import BeautifulSoupos.chdir(sys.path[0])try: from urlparse import parse_qsl,urlparse from urllib import urlencode,quoteexcept: from ur

2012-12-16 20:03:59 1986

原创 隐藏django model

class MyModelAdmin(admin.ModelAdmin): def get_model_perms(self, request): """ Return empty perms dict thus hiding the model from admin index. """ return {}然后就

2012-12-03 22:54:12 957

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

Tkinter Programming Code By Examples

Tkinter python 例子,快速学习标准库实现python编程

2012-04-17

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

PHP Fuzzing行动——源码审计

目录: Section 1: 20种PHP源码快速审计方式 Section 2: PHP源码审计自动化( PHP Fuzzer ) 风险级别: ■ Low ■ Medium ■ High

2012-02-06

类似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关注的人

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