如何找到微信小程序入口

如何找到微信小程序入口,第1张

微信小程序入口非常的多,目前微信已经开发了60多个入口,比较常见的入口有:

1、线下扫码

线下扫码是常见的微信小程序入口之一,而且它是微信小程序最基础的获取方式。也就是我们常说的扫一扫,大家可以打开扫一扫,通过微信扫描线下二维码的方式进入微信小程序。

2、微信搜索

搜一搜也是让你看有快速打开微信小程序的常用方法之一,您可以在微信客户端最上方的搜索窗口,或者在“发现-小程序”中,也可以通过搜索进入小程序。如下图所示:

3、公众号关联

现在很多的商家都会把自己的公众号关联微信小程序,所以大家也可以通过公众号资料页、图文消息、模板消息等场景进入小程序。

4、好友推荐

朋友分享,也是一个让你快速进入微信小程序入口之一,当你发现一个好玩的或者实用的小程序,可以将这个小程序,或者它的某一个页面转发给好友或群聊。

5、历史记录

历史记录也是常见的打开小程序的方法之一,一般当你使用过某个小程序后,在微信页面下拉,或者在微信客户端的“发现-小程序”里的列表,就可以看到这个小程序,想要再次使用它时,通过列表中的历史记录就可以进入。

小程序流量入口很多,其他小程序入口,小编这里就不一一详细介绍了,下面是小程序入口清单,供大家查阅:

在一个线程出现异常行为时,比如说CPU占用率过高,抛出异常等,你一定想知道这个线程是由哪个模块创建的。因此无论在哪个 *** 作系统上,获取线程名称是诊断线程相关问题的重要一步。

从线程ID获取线程名称通常的方法是,先获取该线程的入口地址,然后枚举进程内所有已加载模块,最后判断线程入口地址落在哪个加载模块范围内。枚举进程内已加载模块可用Win32标准的CreateToolhelp32Snapshot/Module32First/Module32Next系列ToolHelp API得到。获取线程入口地址则没有线程的Win32 API可用。不过在Windows NT based *** 作系统上(包括Windows NT 4.0/2000/XP/2003,等),有一个未公开的Native API可用:NtQueryInformationThread。其声明如下:

DWORDWINAPINtQueryInformationThread(

HANDLEThreadHandle,

THREAD_INFORMATION_CLASSThreadInformationClass,

PVOIDThreadInformation,

ULONGThreadInformationLength,

PULONGReturnLength)获取线程入口地址可用:

DWORDGetThreadStartAddress(DWORDdwThreadId){HANDLEhThread=OpenThread(THREAD_ALL_ACCESS,FALSE,dwThreadId)

DWORDretaddr,len,errorretaddr=len=0error=NtQueryInformationThread(hThread,9,

&retaddr,

sizeof(retaddr),

&len)CloseHandle(hThread)if(error!=0)retaddr=0returnretaddr}在Windows CE上就没这么幸运了,没有任何现成的API可用。官方Windows CE Base Team的blog对这个问题的回答是可以用Remote Kernel Tracker,不过这需要你build一个特殊的kernel image,enable一些profiler功能-这在显示的问题诊断中显然是不实际的。那么有没有办法不需要什么特殊的配置就可像Windows桌面 *** 作系统那样获得入口地址呢?有是有的,不过需要一些hack手段。仔细研究CE下的Thread内核数据结构,就会发现Thread结构中有一项是记录线程入口地址的。typedefstructThread{DWORD_1[3]PPROCESSpProc/*0C:pointertocurrentprocess*/PPROCESSpOwnerProc/*10:pointertoownerprocess*/DWORD_2[18]DWORDdwStartAddr/*5c:threadPCatcreation,usedtogetthreadname*/DWORD_3[10]}THREAD,*PTHREAD/*Thread*/因此要做的就是想办法根据线程ID或handle得到这个数据。再研究,发现线程的Thread内核数据结构可通过句柄得到:PTHREADpTh=HandleToThread(ThreadHandle)

而且,在Windows CE下,线程ID和其handle的值是一样的!!因此我们可以写一个这样的函数从线程ID拿到入口地址:

DWORDGetThreadStartAddress(DWORDdwThreadId){DWORDdwStartAddress=0BOOLfOldMode=SetKMode(TRUE)PTHREADpTh=HandleToThread((HANDLE)dwThreadId)if(pTh){dwStartAddress=(DWORD)MapPtrToProcess((LPVOID)pTh-dwStartAddr,pTh-pOwnerProc-hProc)}returndwStartAddress}为了使用这些内核数据结构,我们还需要另外一些辅助结构和函数,比较完整的代码如下。当然,官方肯定是不建议这么做的,但是重要的是解决问题,你说呢。typedefstructProcess{DWORD_1[2]HANDLEhProc/*08:handleforthisprocess,neededonlyforSC_GetProcFromPtr*/}PROCESS,*PPROCESStypedefstructThread{DWORD_1[3]PPROCESSpProc/*0C:pointertocurrentprocess*/PPROCESSpOwnerProc/*10:pointertoownerprocess*/DWORD_2[18]DWORDdwStartAddr/*5c:threadPCatcreation,usedtogetthreadname*/DWORD_3[10]}THREAD,*PTHREAD/*Thread*/typedefstructcinfo{characName[4]/*00:objecttypeIDstring*/uchardisp/*04:typeofdispatch*/uchartype/*05:apihandletype*/ushortcMethods/*06:#ofmethodsindispatchtable*/constPFNVOID*ppfnMethods/*08:ptrtoarrayofmethods(inserveraddressspace)*/constDWORD*pdwSig/*0C:ptrtoarrayofmethodsignatures*/PPROCESSpServer/*10:ptrtoserverprocess*/}CINFO/*cinfo*/typedefCINFO*PCINFOtypedefstruct_HDATAHDATA,*PHDATAstruct_HDATA{DWORD_1[2]/*00:linksforactivehandlelist*/HANDLEhValue/*08:Currentvalueofhandle(nonce)*/DWORDlock/*0C:accessinformation*/DWORDref/*10:referenceinformation*/constCINFO*pci/*14:ptrtoobjectclassdescriptionstructure*/PVOIDpvObj/*18:ptrtoobject*/DWORDdwInfo/*1C:extrahandleinfo*/}/*20:sizeof(HDATA)*/#ifdefx86structKDataStruct{LPDWORDlpvTls/*0x000Currentthreadlocalstoragepointer*/HANDLEahSys[NUM_SYS_HANDLES]/*0x004Ifthismoves,changekapi.h*/DWORD_1[4]ulonghandleBase/*0x094baseaddressofhandletable*/}/*KDataStruct*/#endif#ifdefARMstructKDataStruct{LPDWORDlpvTls/*0x000Currentthreadlocalstoragepointer*/HANDLEahSys[NUM_SYS_HANDLES]/*0x004Ifthismoves,changekapi.h*/DWORD_1[6]ulonghandleBase/*0x09chandletablebaseaddress*/}/*KDataStruct*/#endif#defineHandleToThread(h)((THREAD*)GetObjectPtrByType((h),SH_CURTHREAD))#defineHANDLE_ADDRESS_MASK0x1ffffffcvoidh2p(HANDLEh,PHDATA&phdRet){if((ulong)h<NUM_SYS_HANDLES+SYS_HANDLE_BASE&&(ulong)h=SYS_HANDLE_BASE)h=((KDataStruct*)PUserKData)-ahSys[(uint)h-SYS_HANDLE_BASE]if(h){phdRet=(PHDATA)(((ulong)h&HANDLE_ADDRESS_MASK)+((KDataStruct*)PUserKData)-handleBase)if(phdRet-hValue!=h)phdRet=0}elsephdRet=0}PVOIDGetObjectPtrByType(HANDLEh,

start、main等标号,只是程序设计尤其是汇编语言中习惯使用的标识符,不是汇编语言的规定。汇编语言中,程序的入口由伪指令END后面的标号来指定。

END 标号 这个标号指定程序的入口

例如,

END bubbling

补充回答:这个标号是要在代码段中明确定义的。如,

data segment

mydata db ?

data ends

code segment

assume cs:code,ds:data

bubbling:

.

.

.

mov ah,4ch

int 21h

code ends

end bubbling


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7965177.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-12
下一篇 2023-04-12

发表评论

登录后才能评论

评论列表(0条)

保存