2016-07-22 116 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()); 

}