No edit session in the progress

运行环境:开发环境:Windows7旗舰版64bit、VisualStudio2008 With SP1、ArcEngine10.0、NetFrameWork4.0、IIS7和C#开发语言。

问题描述:通过AE编写的WebService在进行调试时,在网络进行流向初始化的时候发生错误“No edit session in the progress”(有时也会提示“这个集合中找不到此项目”错误,两者通过同一方式处理即可)。

看到这个错误首先认为是没有开启编辑功能导致的,但是我的编辑确实开启了,通过IsBeingEdited()方法确定编辑状态没有问题。

网上很少想过错误的信息,大体看了一下分为以下几种吧:

1、没有开启编辑状态。(这个通过检查后直接排除)

2、开启编辑的工作空间下不包含所需要编辑的要素,即编辑空间不一致的问题。(我通过反复检查后确定所编辑的网络以及构成网络的所有数据均在同一个数据集下面,开启的为数据集的编辑状态,两者在编辑空间上是一致的,因此这个也排除掉)

3、可能使用高级编辑会导致这个问题,删除网络等即可正常使用。(我用的就是网络,网络肯定不可以删除啊!!!这个也排除掉了)

以为之前一直是做CS项目,第一次编写WebService,那我觉得这是否是因为WebService引发的问题呢,因此我搭建了一个CS项目测试程序,结果还是出现同样的问题。

难道是网络的问题?因此我在相同的代码下,将网络流向初始化代码修改为最基本的要素编辑代码(简单的属性赋值),结果同样出现错误,但是错误提示信息发生改变:

Objects in this class cannot be updated outside an edit session

在网上查看了这个错误的解决方式,其中一部分解决方式和之前错误的解决方式相同(即上面列出的三条),但是也多了其他几种处理方法:

1、2、3同上面列出的三条。

4、检查ArcGIS Engine的License文件的授权是否设置了ArcGIS Engine 的GEOEdit权限。

5、检查是否注册了版本。(通过检查没有问题)

6、检查是否在数据库有与该图层有关系的图层,如拓扑关系,相连的注记层等。这些图层会占用编辑图层,出现错误。(我的所有数据都在一起,开启整体编辑,应该没有问题)

看到这个我将重点放在第四条,于是在编辑之前方式许可初始化的代码,可是还是不行。后来查看许可初始化知道要在程序初始化时候进行初始化处理,因此将代码移植到程序初始化中,再次运行程序,问题解决!

下面附程序许可初始化代码:

   1: ESRI.ArcGIS.RuntimeManager.Bind(ESRI.ArcGIS.ProductCode.EngineOrDesktop);
   2: AoInitialize aoi = new AoInitializeClass();
   3: esriLicenseProductCode productCode = esriLicenseProductCode.esriLicenseProductCodeEngineGeoDB;
   4: if (aoi.IsProductCodeAvailable(productCode) == esriLicenseStatus.esriLicenseAvailable)
   5: {
   6:     aoi.IsProductCodeAvailable(productCode);
   7:     if (aoi.Initialize(productCode) != ESRI.ArcGIS.esriSystem.esriLicenseStatus.esriLicenseCheckedOut)
   8:         aoIniMsg = ",请检查ArcEngine中的GDBEdit许可!";
   9: }
  10: else
  11:     aoIniMsg = ",请检查ArcEngine中的GDBEdit许可!";

 

整个问题我弄了两三天才解决,真费事啊,不过后来在WebService部署的时候又出现了这个问题,原因是初始化许可失败导致的,估计和程序锁部署的服务器有关(但是查看服务器上的Desktop和AE许可均没有问题),好费事啊(又弄了一天),后来不知道咋地重新把ArcGIS和IIS相关服务都重启了一下就可以了,希望知道原因的同志们告诉一下,在此先行谢过!

posted on 2014-07-18 10:11  jingkunliu  阅读(1013)  评论(0编辑  收藏  举报

导航