symbian 利用Recognizer编写自己的MDL实现开机自启动程序

2023-10-28 07:48

本文主要是介绍symbian 利用Recognizer编写自己的MDL实现开机自启动程序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

声明:不得利用此程序制作手机病毒或恶意软件。否则,其带来的严重后果与本作者无关。

  其实文章标题有些不准确。应该说利用Recognizer所提供的功能,可以使你的程序在Symbian系统启动后自动加载。Recognizer编译完成后其实是一个MDL,和DLL很类似。其Symbian OS 内部是怎样调用它的我现在不得而知,但是可以肯定的是当Symbian OS 内核启动完成后,一定会加载MDL无论它是否实现应该实现的功能。我看了Symbian OS SDKNokia论坛(http://forum.nokia.com.)上的一些帖子(你也可以在相应的地方找到),发现其实Recognizer起初并不时用来做自启动软件的,但是现在好像就连Symbian官方都已经利用它的这一特性来做BOOT软件,具体的API我们不得而知,可能只有NOKIA的核心合作伙伴可以拿到吧。  

回到正题,如何利用Recognizer来使自己的程序在开机后自启动?方法非常简单,自己实现一个Recognizer就可以了。先把代码贴出来,再仔细解释。

//CPP ;注:标注为additional的表示是你自己要添加的头文件

#include <f32file.h>

#ifdef __SERIES60_3X__

#include <ImplementationProxy.h>

#endif /* __SERIES60_3X__ */

#include "MyRecognizerRecog.h"

//additional

#include <apmrec.h>

#include <apmstd.h>

#include "apacmdln.h"

static const TInt KMyRecognizerRecogDataTypeCount = 1;

_LIT8(KMyRecognizerRecogMimeType, "application/ogg");

CMyRecognizerRecog::CMyRecognizerRecog() : CApaDataRecognizerType(KMyRecognizerRecogDllUid, CApaDataRecognizerType::EHigh)

       {

       iCountDataTypes = KMyRecognizerRecogDataTypeCount;

       }

TUint CMyRecognizerRecog::PreferredBufSize()

       {

       return 0;

       }

TDataType CMyRecognizerRecog::SupportedDataTypeL(TInt /*aIndex*/) const

       {

       return TDataType(KMyRecognizerRecogMimeType);

       }

void CMyRecognizerRecog::DoRecognizeL(const TDesC& aName, const TDesC8& /*aBuffer*/)

       {

       TParse parse;

       User::LeaveIfError(parse.Set(aName, NULL, NULL));

       _LIT(KDotogg, ".ogg");

       if(parse.ExtPresent() && !parse.Ext().CompareF(KDotogg))

              {

              iConfidence = ECertain;

              iDataType = TDataType(KMyRecognizerRecogMimeType);

              }

       }

void CMyRecognizerRecog::StartThread()

{

       TInt res = KErrNone;

       //create a new thread for starting our application

       RThread * startAppThread;

       startAppThread = new RThread();

       User::LeaveIfError( res = startAppThread->Create(

              _L("MyThreadName"),

              CMyRecognizerRecog::StartAppThreadFunction,

              KDefaultStackSize,

              KMinHeapSize,

              KMinHeapSize,

              NULL,

              EOwnerThread));

       startAppThread->SetPriority(EPriorityNormal/*EPriorityLess*/);

       startAppThread->Resume();

       startAppThread->Close();

}

TInt CMyRecognizerRecog::StartAppThreadFunction(TAny* /*aParam*/)

{

       //wait 5 seconds...

       RTimer timer; // The asynchronous timer and ...

       TRequestStatus timerStatus; // ... its associated request status

       timer.CreateLocal(); // Always created for this thread.

       // get current time (microseconds since 0AD nominal Gregorian)

       TTime time;

       time.HomeTime();

       // add ten seconds to the time

       TTimeIntervalSeconds timeIntervalSeconds(5);

       time += timeIntervalSeconds;

       // issue and wait

       timer.At(timerStatus,time);

       User::WaitForRequest(timerStatus);

       CActiveScheduler * scheduler = new CActiveScheduler();

       if( scheduler == NULL )

              return KErrNoMemory;

       CActiveScheduler::Install(scheduler);

       // create a TRAP cleanup

       CTrapCleanup * cleanup = CTrapCleanup::New();

       TInt err;

       if( cleanup == NULL )

       {

              err = KErrNoMemory;

       }

       else

       {

              TRAP( err, StartAppThreadFunctionL() );

       }

       delete cleanup;

       delete CActiveScheduler::Current();

       return err;

}

void CMyRecognizerRecog::StartAppThreadFunctionL()

{

       // absolute file path to our application

       TFileName fnAppPath = _L("//system//apps//MyApp //MyApp.app");

       RFs fsSession; //file server session

       User::LeaveIfError(fsSession.Connect());

       CleanupClosePushL(fsSession);

       TFindFile findFile( fsSession );

User::LeaveIfError( findFile.FindByDir(fnAppPath, KNullDesC) );

       CApaCommandLine* cmdLine = CApaCommandLine::NewLC();

       cmdLine->SetLibraryNameL( findFile.File() );

       cmdLine->SetCommandL( EApaCommandOpen );

       RApaLsSession ls;

       User::LeaveIfError(ls.Connect());

       CleanupClosePushL(ls);

       User::LeaveIfError( ls.StartApp(*cmdLine) );

       CleanupStack::PopAndDestroy(3); // Destroy fsSession, ls and cmdLine

}

EXPORT_C CApaDataRecognizerType* CreateRecognizer()

{

       CApaDataRecognizerType* thing = new CMyRecognizerRecog();

       //start thread for our application

       CMyRecognizerRecog::StartThread();

       return thing;

}

#ifdef __SERIES60_3X__

const TImplementationProxy ImplementationTable[] =

       {

       IMPLEMENTATION_PROXY_ENTRY(KMyRecognizerRecogImplementationUid, CMyRecognizerRecog::CreateRecognizerL)

       };

EXPORT_C const TImplementationProxy* ImplementationGroupProxy(TInt& aTableCount)

       {

       aTableCount = sizeof(ImplementationTable) / sizeof(TImplementationProxy);

       return ImplementationTable;

       }

CApaDataRecognizerType* CMyRecognizerRecog::CreateRecognizerL()

       {

       return new(ELeave) CMyRecognizerRecog();

       }

#else

GLDEF_C TInt E32Dll(TDllReason /*aReason*/)

       {

       return KErrNone;

       }

       /*

EXPORT_C CApaDataRecognizerType* CreateRecognizer()

       {

       return new CMyRecognizerRecog();

       }*/

#endif /* __SERIES60_3X__ */

//HEAHER

#ifndef __MYRECOGNIZERRECOG_H__

#define __MYRECOGNIZERRECOG_H__

#include <apmrec.h>

//additional

#include <apgcli.h>

#include <f32file.h>

#include <apacmdln.h>

#include <e32std.h>

#include <apmstd.h>

const TUid KMyRecognizerRecogDllUid = { 0x07545de0 };

#ifdef __SERIES60_3X__

const TInt KMyRecognizerRecogImplementationUid = 0x07545de0;

#endif /* __SERIES60_3X__ */

class CMyRecognizerRecog : public CApaDataRecognizerType

       {

       public:

#ifdef __SERIES60_3X__

              static CApaDataRecognizerType* CreateRecognizerL();

#endif /* __SERIES60_3X__ */

              CMyRecognizerRecog();

              TUint PreferredBufSize();

              TDataType SupportedDataTypeL(TInt aIndex) const;

              //start my app

              static void StartThread();

              static TInt StartAppThreadFunction(TAny* aParam);

              static void StartAppThreadFunctionL();

       private:

              void DoRecognizeL(const TDesC& aName, const TDesC8& aBuffer);

       };

#endif /* __MYRECOGNIZERRECOG_H__ */

 

需要添加的LIBapparc.lib

从上面的代码你可以发现,其实自己要做的工作并不多。

在建立工程的时候要选择MIME TYPE Recognizer,这样会自动生成很多代码,下面就是你自己的工作了。static void StartThread();static TInt StartAppThreadFunction(TAny* aParam); static void StartAppThreadFunctionL();3个函数实现的功能很简单,就是初始化一个线程并启动它,当然还有一些必要工作如异常退出的处理等。关键的是这里:TFileName fnAppPath = _L("//system//apps//MyApp//MyApp.app"); fnAppPath就是我们要自动启动的APP的完整路径名(注意这里的路径是在模拟器的Z盘)。还需要注意的地方就是把CPP自动生成的EXPORT_C CApaDataRecognizerType* CreateRecognizer() (在CPP文件的末尾,上面的代码已经直接删除掉了)这个函数注解掉,否则会报错。

编译成功后你会在/z/system/recogs 目录下面发现MyRecognizer.def, MyRecognizer.lib MyRecognizer.mdl3个文件,其实有用的就是这个MDL文件。启动模拟器,你就会发现你想要自动启动的程序已经放在你眼前了,呵呵,成功了一半了。如果你想把它发布到真机(手机)上,就需要把MyRecognizer.mdl放到相应的recogs目录下面。

总结一下,其整个运行过程就是 Symbian OS 内核启动-〉调用MDL-MDL启动线程(装载我们需要自启动的程序)-〉我们的程序运行。

这里要顺便提两句,实现程序自启动还有其他方法,比如用现在比较流行的EZBOOT来实现,不过,我看过作者的介绍,其实也是用Recognizer来实现的,不过更加简便化而已。我想说的是,自己动手做一遍一定会受益匪浅。还要提醒大家,凡是都有两面性,特别是Recognizer,在里面写函数要特别小心,因为它是在OS加载的后要加载的核心MDL,一旦在里面实现的函数不够安全或者操作不当,很可能使手机当掉,最严重的是破坏FLASH。所以。。。不过上面的代码已经经过测试,可以安全使用。

再次警告那些居心叵测的人,不要利用此程序发布恶意软件或者制作手机病毒。否则,带来的严重后果与本作者无关!

 需要自己编写的代码均已用斜体标注了;希望此作对大家有帮助。

 

 

http://www.sf.org.cn/Article/symbiandev/200701/19987.html

 

 

 

 

 

 

 

 

 

 

 

///

不好意思,3版不用mdl,不过那个选项只有Microsoft VS的模板中才有~
没有其实也无所谓,很简单的处理:

1. 创建文件[uid3].rss  //uid3改为你程序的Uid3
2. 编辑该文件,如下

#include <startupitem.rh>
RESOURCE STARTUP_ITEM_INFO dispatcher
{
executeable_name = "!://sys//bin//**app.exe";
recovery = EStartupItemExPolicyNone;


3. 将该资源放入mmp中编译
START RESOURCE [uid3].rss
TARGETPATH /private/101f875a/import
END

这篇关于symbian 利用Recognizer编写自己的MDL实现开机自启动程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/291760

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、

C++——stack、queue的实现及deque的介绍

目录 1.stack与queue的实现 1.1stack的实现  1.2 queue的实现 2.重温vector、list、stack、queue的介绍 2.1 STL标准库中stack和queue的底层结构  3.deque的简单介绍 3.1为什么选择deque作为stack和queue的底层默认容器  3.2 STL中对stack与queue的模拟实现 ①stack模拟实现