2016-07-22 113 views
0

我创建了一个简单的示例,使用apache化学在露天中创建文档。我工作正常,能够创建文档。但是,当我重新启动我的机器和露天服务器那么现在同样的程序给我的错误 -Alfresco:无法创建目录

org.apache.chemistry.opencmis.commons.exceptions.CmisRuntimeException:06220002无法创建文件的存放目录:/家居/户外/ alfresco-community/alf_data/contentstore/2016/7/22/16/57 at org.apache.chemistry.opencmis.client.bindings.spi.atompub.AbstractAtomPubService.convertStatusCode(AbstractAtomPubService.java:523) at org。 apache.chemistry.opencmis.client.bindings.spi.atompub.AbstractAtomPubService.post(AbstractAtomPubService.java:717) at org.apache.chemistry.opencmis.client.bindings.spi.atompub.ObjectServiceImpl.createDocument(ObjectServiceImpl.java: 122) at org.apache.chemistry。 opencmis.client.runtime.SessionImpl.createDocument(SessionImpl.java:1165) at org.apache.chemistry.opencmis.client.runtime.FolderImpl.createDocument(FolderImpl.java:77) at org.apache.chemistry.opencmis。 client.runtime.FolderImpl.createDocument(FolderImpl.java:460) at com.bizruntime.alfresco.cmis.upload.C​​reateDocument.createDocumentInAlfrescoRepository(CreateDocument.java:81) at com.bizruntime.alfresco.cmis.upload.C​​reateDocumentTest。 testCreateDocInAlfrescoRepository(CreateDocumentTest.java:16) 在sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法) 在sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java :43) at java .lang.reflect.Method.invoke(Method.java:606) at org.junit.runners.model.FrameworkMethod $ 1.runReflectiveCall(FrameworkMethod.java:50) at org.junit.internal.runners.model.ReflectiveCallable。运行(ReflectiveCallable.java:12) at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47) at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 在org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325) 在org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78) 在org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner。 java:57) at org.junit.runners.ParentRunner $ 3.run(ParentRunner.java:290) at org.junit.r在org.junit.runners.ParentRunner.access $ org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288) (ParentRunner.java:58) at org.junit.runners.ParentRunner $ 2.evaluate(ParentRunner.java:268) at org.junit.runners.ParentRunner.run(ParentRunner.java:363) at org.eclipse.jdt.internal.junit4.runner .JUnit4TestReference.run(JUnit4TestReference.java:86) at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner .runTests(RemoteTestRunner.java:459) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675) at org.eclipse.jdt.i nternal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382) 在org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)

请别人帮忙。

+0

你的'alfresco.log'文件有什么特别的例外?应该有一个“由...引起”的第二个异常,该问题解释了回复的 – Gagravarr

+0

thanx问题,当我从终端启动catalina.sh时,此异常显示** java.io.FileNotFoundException:alfresco.log(Permission denied)** – deen

+0

你是什么意思与目录,'文件夹'? –

回答

1

我想你的主机上的文件权限有问题!要验证这个问题,您需要使用共享界面在户外上传/创建文档,如果您没有成功,这意味着我的怀疑是正确的:运行tomcat实例的系统用户无权写入alf_data目录。

可能的原因:使用不同的用户系统配置错误,您正在运行的露天服务....

候选解决方案:

  1. 检测哪个用户应该运行的露天(可能是/home/alfresco的拥有者)你可以通过运行它找到它:

    [email protected]$>ls -la /home/alfresco 
    
  2. 假设用户名是alfresco,主机上运行此脚本,用root帐号:

    [email protected]$>chown alfresco /home/alfresco -R 
    
  3. 使用同一帐户

+0

thnx答复,当我再次重新启动我的系统并执行相同的程序,然后它运行良好。我不明白为什么? – deen

+2

你第一次用错用户在露天运行 –

0

试试这个工作对我罚款

重新启动服务
public static void createNewFolderIn(String serverUrl, String username, String password, String path, String folderName) { 
    Folder root = getFolderByPath(serverUrl, username, password, path); 
    Map<String, Object> properties = new HashMap<>(); 
    properties.put(PropertyIds.OBJECT_TYPE_ID, BaseTypeId.CMIS_FOLDER.value()); 

    properties.put(PropertyIds.NAME, folderName); 
    List<Ace> addAces = new LinkedList<>(); 
    List<Ace> removeAces = new LinkedList<>(); 
    List<Policy> policies = new LinkedList<>(); 
    Folder newFolder = root.createFolder(properties, policies, addAces, removeAces, getSession(serverUrl, username, password).getDefaultContext()); 

}